今天遇到一个问题,就是用post方式传递参数,程序在vs中完美调试,但是在iis中,就无法运行了,显示传递的参数获取不到,报错了,查看浏览器请求情况,错误500,服务器内部错误,当时第一想法是接收方式有问题,换了无数次接收方式,都没有效,后来在请求情况的,Response中发现,其实根本原因是由于post参数中不能包含html代码,设计到跨域攻击...,所以被禁止了。

  微软给出的建议是 ASP.NET Web窗体中禁用请求验证 ,我是没成功,后来我查到其实可以用在前端用js base64加密,后端再用.net base64解密一下就好了,就能完美避过html代码这个问题,情景介绍完毕,下面上代码。

  js 加密:

  1 function Base64() {
  2
  3                 // private property
  4                 _keyStr = "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/=";
  5
  6                 // public method for encoding
  7                 this.encode = function (input) {
  8                     var output = "";
  9                     var chr1, chr2, chr3, enc1, enc2, enc3, enc4;
 10                     var i = 0;
 11                     input = _utf8_encode(input);
 12                     while (i < input.length) {
 13                         chr1 = input.charCodeAt(i++);
 14                         chr2 = input.charCodeAt(i++);
 15                         chr3 = input.charCodeAt(i++);
 16                         enc1 = chr1 >> 2;
 17                         enc2 = ((chr1 & 3) << 4) | (chr2 >> 4);
 18                         enc3 = ((chr2 & 15) << 2) | (chr3 >> 6);
 19                         enc4 = chr3 & 63;
 20                         if (isNaN(chr2)) {
 21                             enc3 = enc4 = 64;
 22                         } else if (isNaN(chr3)) {
 23                             enc4 = 64;
 24                         }
 25                         output = output +
 26                             _keyStr.charAt(enc1) + _keyStr.charAt(enc2) +
 27                             _keyStr.charAt(enc3) + _keyStr.charAt(enc4);
 28                     }
 29                     return output;
 30                 }
 31
 32                 // public method for decoding
 33                 this.decode = function (input) {
 34                     var output = "";
 35                     var chr1, chr2, chr3;
 36                     var enc1, enc2, enc3, enc4;
 37                     var i = 0;
 38                     input = input.replace(/[^A-Za-z0-9\+\/\=]/g, "");
 39                     while (i < input.length) {
 40                         enc1 = _keyStr.indexOf(input.charAt(i++));
 41                         enc2 = _keyStr.indexOf(input.charAt(i++));
 42                         enc3 = _keyStr.indexOf(input.charAt(i++));
 43                         enc4 = _keyStr.indexOf(input.charAt(i++));
 44                         chr1 = (enc1 << 2) | (enc2 >> 4);
 45                         chr2 = ((enc2 & 15) << 4) | (enc3 >> 2);
 46                         chr3 = ((enc3 & 3) << 6) | enc4;
 47                         output = output + String.fromCharCode(chr1);
 48                         if (enc3 != 64) {
 49                             output = output + String.fromCharCode(chr2);
 50                         }
 51                         if (enc4 != 64) {
 52                             output = output + String.fromCharCode(chr3);
 53                         }
 54                     }
 55                     output = _utf8_decode(output);
 56                     return output;
 57                 }
 58
 59                 // private method for UTF-8 encoding
 60                 _utf8_encode = function (string) {
 61                     string = string.replace(/\r\n/g, "\n");
 62                     var utftext = "";
 63                     for (var n = 0; n < string.length; n++) {
 64                         var c = string.charCodeAt(n);
 65                         if (c < 128) {
 66                             utftext += String.fromCharCode(c);
 67                         } else if ((c > 127) && (c < 2048)) {
 68                             utftext += String.fromCharCode((c >> 6) | 192);
 69                             utftext += String.fromCharCode((c & 63) | 128);
 70                         } else {
 71                             utftext += String.fromCharCode((c >> 12) | 224);
 72                             utftext += String.fromCharCode(((c >> 6) & 63) | 128);
 73                             utftext += String.fromCharCode((c & 63) | 128);
 74                         }
 75
 76                     }
 77                     return utftext;
 78                 }
 79
 80                 // private method for UTF-8 decoding
 81                 _utf8_decode = function (utftext) {
 82                     var string = "";
 83                     var i = 0;
 84                     var c = c1 = c2 = 0;
 85                     while (i < utftext.length) {
 86                         c = utftext.charCodeAt(i);
 87                         if (c < 128) {
 88                             string += String.fromCharCode(c);
 89                             i++;
 90                         } else if ((c > 191) && (c < 224)) {
 91                             c2 = utftext.charCodeAt(i + 1);
 92                             string += String.fromCharCode(((c & 31) << 6) | (c2 & 63));
 93                             i += 2;
 94                         } else {
 95                             c2 = utftext.charCodeAt(i + 1);
 96                             c3 = utftext.charCodeAt(i + 2);
 97                             string += String.fromCharCode(((c & 15) << 12) | ((c2 & 63) << 6) | (c3 & 63));
 98                             i += 3;
 99                         }
100                     }
101                     return string;
102                 }
103             }

  使用方式:

1          //1.加密
2          var base = new Base64();
3          var result = base.encode(str);

  .net 解密:

1         /// <summary>
2         /// Base64解密,采用utf8编码方式解密
3         /// </summary>
4         /// <param name="result">待解密的密文</param>
5         /// <returns>解密后的字符串</returns>
6         public static string Base64Decode(string result)
7         {
8             return Base64Decode(Encoding.UTF8, result);
9         }

  另外附上js加密的链接地址,可以多学习一下,https://blog.csdn.net/u012369749/article/details/73784897,哈哈,事已至此,问题就解决了。

转载于:https://www.cnblogs.com/peng0731/p/10472592.html

post 传递参数中包含 html 代码解决办法,js加密,.net解密相关推荐

  1. ajax参数中有加号,浅谈在js传递参数中含加号(+)的处理方式

    一般情况下,URL 中的参数应使用 url 编码规则,即把参数字符串中除了 -_. 之外的所有非字母数字字符都将被替换成百分号(%)后跟两位十六进制数,空格则编码为加号(+). 但是对于带有中文的参数 ...

  2. 关于cmd中路径包含空格的解决办法

    关于cmd中路径包含空格的解决办法 很多人曾经都纠结于cmd中路径没有空格,昨天看到一篇文章,深受启发 1)最简单的方法就是给路径名上加上"" 然后cd或执行即可: 2)用缩写.比 ...

  3. linux eclipse乱码,Eclipse项目中乱码问题的解决办法

    一.产生的原因: 1.Http协议进行通信的时候是基于请求和响应的,传输的内容我们称之为报文! 2.Http协议会按照一定的规则将报文编码,然后在读取的时候再使用响应的解码格式进行解码! 3.这个一定 ...

  4. 因为返回有true ajax提示进入错误,jquery ajax中error返回错误解决办法

    转自:https://www.jb51.net/article/72198.htm 进入百度搜索此问题,发现有人这么说了一句 Jquery中的Ajax的async默认是true(异步请求),如果想一个 ...

  5. EF Power Tool 参数错误 HRESULT:0x80070057 (E_INVALIDARG)) 解决办法

    EF Power Tool 参数错误  HRESULT:0x80070057 (E_INVALIDARG)) 解决办法 从EF4.1开始引入了Code First的开发模式,并提供了工具Entity ...

  6. 关于WINSOCK.H与winsock2.h中的重定义解决办法分析

    windows.h与winsock2.h的包含顺序 大凡在Windows平台下用C++做网络开发很多时候都会同时包含这两个头文件,如若顺序不当(windows.h先于winsock2.h)就会出现很多 ...

  7. (PD)PowerDesigner设计表时显示注释列Comment,Columns中没有Comment的解决办法(关联MySQL)

    1.在所要编辑的表上双击,打开Table Properties窗口,并将上面的选项卡切换到Columns,如下图: 2.点击Customize Columns and Filter按钮,下图红框中的按 ...

  8. 计算机实验中发现的问题及解决方法,计算机实验室管理中的问题及解决办法论文...

    一名合格的实验室管理人员,不仅要有丰富的计算机知识,还要有很强的较动手能力,当然,管理人员的服务水平也很重要.因为,实验室管理人员素质高低,低则决定一节课的课堂教学效率,高则直接影响实验室的整体工作效 ...

  9. 织物印花中的常见问题与解决办法

    织物印花中的常见问题与解决办法 1.平网织物印花中压版问题的解决方法 主要原因:1. 网框接版处得色率过深:2. 网框贴边不得当:3. 色浆粘度太低. 解决方法: 网框接版处得色率过深,会产生横向接版 ...

最新文章

  1. 如何手动的用jigloo设计器关联java界面文件 jigloo 设计器失去关联解决
  2. 使用 vscode 调试前端代码
  3. 【Linux】文件特殊权限 SUID/SGID/Sticky Bit
  4. Oralce-清除数据的两种思路
  5. C++通过hiredis连接到redis
  6. SpringBoot集成Eureka导致返回结果由json变为xml解决方案
  7. android 多个模块,Android 模块化中两个模块之间传递model
  8. include vector 编译出错VC++
  9. mysql数据库连接失败_mysql数据库连接失败是什么原因
  10. 拓端tecdat|R语言混合时间模型预测对时间序列进行点估计
  11. 均线策略python代码_Python版商品期货多品种均线策略
  12. 19华为软件精英挑战赛止步复赛
  13. 红外遥控器-VS1838B/HS0038红外接收方案(包含原理图+PCB+BOM表+程序)
  14. 第6集丨Persistent Objects 和 Caché SQL
  15. 关于pdms中设备参数模板的更新PML代码
  16. SVN各个状态:A C D M G U R I具体含义
  17. tkinter 小说编写器,文本编辑器,小说阅读器
  18. html中正确给table加边框
  19. 第三章:SQL——视图操作
  20. squad战术小队steam服务器搭建教程。

热门文章

  1. 利息高的贷款通过率会高一些吗?
  2. 什么是暗物质?有没有理科大神解答一下啊?
  3. 武汉月薪1万5,感到焦虑怎么办?
  4. 长痘痘了吃什么好得快?
  5. 坐异性朋友的车时,能坐在副驾驶吗?
  6. 营业执照吊销后,股权何去何从?
  7. 文化的作用与本质是什么
  8. 哪些手机支持双wifi?
  9. 开放地址法开放地址法
  10. 我们先来了解下什么是网络爬虫?