paip 提升安全 网站登录密码明文传输的登录高危漏洞解决方案

news/2024/5/12 15:43:00/文章来源:https://blog.csdn.net/sdfhncfw/article/details/83746847

分享一下我老师大神的人工智能教程!零基础,通俗易懂!http://blog.csdn.net/jiangjunshow

也欢迎大家转载本篇文章。分享知识,造福人民,实现我们中华民族伟大复兴!

paip.提升安全---绝大多数网站的登录高危漏洞解决方案

 

作者Attilax, 1466519819@qq.com

 

WEB登录密码明文传输的严重性...1

JS实现 RSA非对称加密算法...1

加解密及传输流程...1

后台产生一对公钥下发给WEB页...2

WEB页JS调用公钥进行加密提交...2

后台校验密码不能为空...3

解密密码...4

密码编码器pwdEncode大部分原码...4

参考:6

WEB登录密码明文传输的严重性

今天,几乎所有的网站都有登录注册模块,登录就要输入用户名和登录密码,并且,用户名和登录密码都是明文传输的,这样就有可能在中途被别人拦截,尤其是在网吧等场合。

 

JS实现 RSA非对称加密算法

所以,很多安全要求较高的网站都不会明文传输密码,它们会使用https来确保传输过程的安全,https是用证书来实现的,证书来自于证书颁发机构,当然了,你也可以自己造一张证书,但这样别人访问你的网站的时候还是会遇到麻烦,因为你自己造的证书不在用户浏览器的信任范围之内,你还得在用户浏览器上安装你的证书,来让用户浏览器相信你的网站,很多用户并不知道如何操作,就算会操作,也能也不乐意干;另一种选择是你向权威证书颁发机构申请一张证书,但这样有一定的门槛,还需要付费,也不是我们乐意干的事。

 

所以使用JS来实现RSA加密是个很好的方法..我的网站是ASP。NET的..真正的难点在于用javascript实现一个和.net的RSA兼容的算法

 

 

加解密及传输流程

后台产生一对公钥私钥

传给WEB页面

登录/注册的时候,使用JS加密

后台解码.

 

 

后台产生一对公钥下发给WEB页

  protected void Page_Load(object sender, EventArgse)

    {

       

 

 

        pwdEncodepe= new pwdEncode();

        string[] ret=pe.PublicKey();

        strPublicKeyExponent=ret[0];

        strPublicKeyModulus=ret[1];

      

    }

    protected string strPublicKeyExponent="";

    protected string strPublicKeyModulus="";

 

 

WEB页JS调用公钥进行加密提交

 

//两个加密文本框,加密后的密码保存在这里..如果是登录页面,只需要一个就可以了

                   <input name="encrypted_pwd" type="hidden" id="encrypted_pwd" />

                          <input name="encrypted_pwd2" type="hidden" id="encrypted_pwd2" />

 

//调用相关JS

                          <SCRIPT type=text/javascript src="/index_files/Account.js"></SCRIPT>

           <script src="/Scripts/jQuery.md5.js" type="text/javascript" ></script>

                 <script src="/Scripts/BigInt.js" type="text/javascript"></script>

                    <script src="/Scripts/RSA.js" type="text/javascript"></script>

                          <script src="/Scripts/Barrett.js" type="text/javascript"></script>

         <script>

 

//从后台得到公钥

var strPublicKeyExponent="<%= strPublicKeyExponent%>";

var strPublicKeyModulus="<%=strPublicKeyModulus%>";

 

 

//加密函数

function cmdEncrypt() {

            setMaxDigits(129);

            var key = new RSAKeyPair(strPublicKeyExponent, "", strPublicKeyModulus);

            var pwdMD5Twice = $("#SignIn_Pword").attr("value");

            var pwdRtn = encryptedString(key, pwdMD5Twice);

            $("#encrypted_pwd").attr("value", pwdRtn);

                    

       //注意:需要清空原密码框

                       $("#SignIn_Pword").attr("value","");

                   

 

       

}

 

//登录按扭事件

function  login_click()

{

 cmdEncrypt() ;

 return true;

}

 

//登录按扭事件注册

$('#SignIn_SignInClt').click=login_click;

$('#SignIn_SignInClt').click(function(){

  login_click();

});

 

 

后台校验密码不能为空

因为使用了加密方式,所以原来的校验需要去掉,使用新的校验方式

 

            loginCheckorlc= new loginCheckor();

            lc.check(Account,Request["encrypted_pwd"]);

 

public bool check(string uname,string pwd)

 

    {

        if (uname=="")

        {

            throw new SystemException("帐¨º号?未¡ä输º?入¨?");

        }

      //  if(uname==null|| uname.Equals(""))

        if (pwd==null ||pwd.Equals(""))

            throw new Exception("密¨¹码?不?能¨¹为a空?");

        //

        //TODO: 在¨²此ä?处ä|添¬¨ª加¨®构1造¨¬函¡¥数ºy逻?辑-

        //

        return true;

    }

 

 

 

如果是注册页面

 

  //ati L921 am

        

            pwdEncodepe= new pwdEncode();

            pe.checkEmpty(Request["encrypted_pwd"],Request["encrypted_pwd2"]);

            string pwd=pe.getPwd(Request["encrypted_pwd"]);

            string Pword2=pe.getPwd(Request["encrypted_pwd2"]);

            pe.check(pwd,Pword2);  //检测两个密码是否相同

            //不能直接检测参数,因为公钥加密后的两个参数不同,需要解密后进行比较

 

解密密码

-------登录后台

     pwdEncodepe= new pwdEncode();

        

            Pword=pe.getPwd(Request["encrypted_pwd"]);

 

 

密码编码器pwdEncode大部分原码

//这里主要使用session来保存RSA加密器和私钥

//发送公

public string[] sendPublicKey()

    {

        RSACryptoServiceProviderrsa;

        if (HttpContext.Current.Session["rsa"]!= null)

            rsa= (RSACryptoServiceProvider)HttpContext.Current.Session["rsa"];

        else

            rsa= new RSACryptoServiceProvider();

 

        //if (string.Compare(Request.RequestType, "get", true) == 0)

        {

            //将?私?钥?存ä?Session中D

            HttpContext.Current.Session["private_key"]=rsa.ToXmlString(true);

            HttpContext.Current.Session["rsa"]=rsa;

        }

        //把ã?公?钥?适º¨º当Ì¡À转Áa换?,ê?准Á?备À?发¤¡é往ª¨´客¨ª户¡ì端?

        pwdEncodepe= new pwdEncode();

        RSAParametersparameter=rsa.ExportParameters(true);

  string      strPublicKeyExponent=pe.BytesToHexString(parameter.Exponent);

  string strPublicKeyModulus=pe.BytesToHexString(parameter.Modulus);

  string[] r=new string[2];

  r[0] =strPublicKeyExponent;

  r[1] =strPublicKeyModulus;

 

  return r;

 

 

    }

 

//解密函数

private static string getDecodePwd(stringpwd)

    {

        RSACryptoServiceProviderrsa;

 

        rsa= (RSACryptoServiceProvider)HttpContext.Current.Session["rsa"];

        pwdEncodepe= new pwdEncode();

        //   RSACryptoServiceProvider rsa = new RSACryptoServiceProvider();

        string strPwdToDecrypt=pwd;

        rsa.FromXmlString((string)HttpContext.Current.Session["private_key"]);

        byte[] result=rsa.Decrypt(pwdEncode.HexStringToBytes(strPwdToDecrypt),false);

        System.Text.ASCIIEncodingenc=new ASCIIEncoding();

        string strPwdMD5=enc.GetString(result);

        return strPwdMD5;

    }

 

 

参考:

用RSA加密实现Web登录密码加密传输 - guogangj -博客园

           

给我老师的人工智能教程打call!http://blog.csdn.net/jiangjunshow

这里写图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.luyixian.cn/news_show_809062.aspx

如若内容造成侵权/违法违规/事实不符,请联系dt猫网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

paip 突破 网站 手机 验证码 的 破解 总结

分享一下我老师大神的人工智能教程&#xff01;零基础&#xff0c;通俗易懂&#xff01;http://blog.csdn.net/jiangjunshow也欢迎大家转载本篇文章。分享知识&#xff0c;造福人民&#xff0c;实现我们中华民族伟大复兴&#xff01;paip.突破 网站 手机 验证码 的 破解 总结 作…

paip 网站扫描安全工具hp WebInspect 使用指南

分享一下我老师大神的人工智能教程&#xff01;零基础&#xff0c;通俗易懂&#xff01;http://blog.csdn.net/jiangjunshow也欢迎大家转载本篇文章。分享知识&#xff0c;造福人民&#xff0c;实现我们中华民族伟大复兴&#xff01;paip.网站扫描安全工具hp WebInspect 使用指…

PAIP WEB程序网站安全扫描检测工具(桌面程序)总结

分享一下我老师大神的人工智能教程&#xff01;零基础&#xff0c;通俗易懂&#xff01;http://blog.csdn.net/jiangjunshow也欢迎大家转载本篇文章。分享知识&#xff0c;造福人民&#xff0c;实现我们中华民族伟大复兴&#xff01;PAIP.WEB程序网站安全扫描检测工具&#xff…

大型网站架构和优化策略和常见处理方案实例

大型在线商务网站的构架设计 本项目是一个在线商品交易平台&#xff0c;平台的主要目的是让企业在平台上发布商品及资讯&#xff0c;用户可以在此平台上购买商品并参与商品的评论。围绕这一目的&#xff0c;系统需要实现商品管理&#xff0c;商品订购&#xff0c;多部门订单处理…

一步步构建大型网站

之前我简单向大家介绍了各个知名大型网站的架构&#xff0c;MySpace的五个里程碑、Flickr的架构、YouTube的架构、PlentyOfFish的架构、WikiPedia的架构。这几个都很典型&#xff0c;我们可以从中获取很多有关网站架构方面的知识&#xff0c;看了之后你会发现你原来的想法很可能…

大型网站的架构设计图

近段时间以来&#xff0c;通过接触有关海量数据处理和搜索引擎的诸多技术&#xff0c;常常见识到不少精妙绝伦的架构图。除了每每感叹于每幅图表面上的绘制的精细之外&#xff0c;更为架构图背后所隐藏的设计思想所叹服。个人这两天一直在搜集各大型网站的架构设计图&#xff0…

国内外大型SNS网站后台架构对比

要问时下什么类型的站点人气最旺&#xff1f;答案当属SNS网站。短短几年的时间&#xff0c;SNS便迅速确立了Web 2.0核心的地位。用户的增长量之快更是让人咂舌&#xff0c;而Facebook访问量首次超越Google的消息也让人觉得SNS的前途不可限量。当然&#xff0c;面对庞大且繁琐的…

各大网站架构总结笔记

各大网站架构总结笔记 记得在大学里不止一次关注网站架构方面的东西了&#xff0c;但每次都是泛泛了解&#xff0c;也没有着重记录&#xff0c;一段时间后对各种架构的思想也就模糊了。这几天不知怎么的又心血来潮&#xff08;可能是快毕业了冲动了&#xff09;想深入了解一下网…

网站启用GZip压缩后,速度快了3倍!

GZip压缩&#xff0c;是一种网站速度优化技术&#xff0c;也是一把SEO优化利器&#xff0c;许多网站都采用了这种技术&#xff0c;以达到提升网页打开速度、缩短网页打开时间的目的。 本文是一篇研究性文章&#xff0c;将通过某个案例来给大家显示网站采用GZip压缩前后的对比效…

中小型网站的缓存策略

在上一篇文章《大型网站系统架构分析》中&#xff0c;介绍了大型网站的系统架构&#xff0c;其中缓存环境非常重要&#xff0c;大型网站往往使用Squid前端缓存服务器群&#xff0c;memcache分布式缓存&#xff0c;负载均衡&#xff0c;CDN等来提升性能。但中小型网站使用这些大…

瞬时响应:网站的高性能架构

什么叫高性能的网站&#xff1f; 两个网站性能架构设计方案&#xff1a;A方案和B方案&#xff0c;A方案在小于100个并发用户访问时&#xff0c;每个请求的响应时间是1秒&#xff0c;当并发请求达到200的时候&#xff0c;请求的响应时间将骤增到10秒。B方案不管是100个并发用户访…

Mysql在大型网站的应用架构演变

本文主要描述在网站的不同的并发访问量级下&#xff0c;Mysql架构的演变,下面分别从不同的角度思考mysql的演变过程.可扩展性架构的可扩展性往往和并发是息息相关&#xff0c;没有并发的增长&#xff0c;也就没有必要做高可扩展性的架构&#xff0c;这里对可扩展性进行简单介绍…

大型网站架构与分布式架构

大型互联网架构 解决问题的通用思路是将分而治之&#xff08;divide-and-conquer&#xff09;&#xff0c;将大问题分为若干个小问题&#xff0c;各个击破。在大型互联网的架构实践中&#xff0c;无一不体现这种思想。 架构目标 低成本:任何公司存在的价值都是为了获取商业利益…

网站分布式架构的演进

来源&#xff1a;知乎 http://www.zhihu.com/question/22764869/answer/31277656首先推荐4本书 大型分布式网站架构设计与实践 http://item.jd.com/11529266.html 大型网站技术架构&#xff1a;核心原理与案例分析 http://item.jd.com/11322972.html 大型网站系统与Java中间件实…

浅谈Web网站架构演变过程及各阶段所用的技术和架构设计

前言 我们以javaweb为例&#xff0c;来搭建一个简单的电商系统&#xff0c;看看这个系统可以如何一步步演变。该系统具备的功能&#xff1a;用户模块&#xff1a;用户注册和管理商品模块&#xff1a;商品展示和管理交易模块&#xff1a;创建交易和管理 阶段一、单机构建网站 网…

大型网站电商网站架构案例和技术架构的示例

大型网站架构是一个系列文档&#xff0c;欢迎大家关注。本次分享主题&#xff1a;电商网站架构案例。从电商网站的需求&#xff0c;到单机架构&#xff0c;逐步演变为常用的&#xff0c;可供参考的分布式架构的原型。除具备功能需求外&#xff0c;还具备一定的高性能&#xff0…

个人网站被攻击,并受到勒索信息,怎么应对?

个人网站被攻击,并受到勒索信息,这已经是第二次了 To recover your lost databases and avoid leaking it: visit http://dbrestore.to and enter your unique token 18dc****52424 and pay the required amount of Bitcoin to get it back. Databases that we have:** Your d…

Web网站通知系统设计

写在前面&#xff1a; 通知系统是网站信息传播机制的重要的一部分&#xff0c;足够写一大章来说明。本文只梳理设计原则&#xff0c;后续相关内容会持续更新。 这里的通知包括但不限于公告、提醒或消息&#xff08;不同使用场景下的功能定义不同&#xff09;。 关于各客户端平台…

主流网站服务器配置组成 主流网站服务器报价

主流网站服务器配置组成 主流网站服务器报价 当今互联网已经是由数量巨大的服务器担当各种服务角色&#xff0c;构成丰富多彩&#xff0c;信息巨大的网络世界&#xff0c;最新英特尔Xeon处理器采用45纳米制程技术&#xff0c;提供第二代四核动力&#xff0c;主频高达 3.2GHz&am…

如何替换页面url_网站改版需要注意什么?如何把SEO影响降到最低?

网站的重新改版意味着网站的主题、页面设计或网站架构没有变化&#xff0c;以便做出相对较大的改变。如果网站主题的内容发生很大变化&#xff0c;域名从一个行业变成另一个行业的内容&#xff0c;从SEO的角度来看&#xff0c;这不是网站的改版&#xff0c;而是网站的自杀。首先…