`
senton
  • 浏览: 211028 次
  • 性别: Icon_minigender_1
  • 来自: 紫禁城
社区版块
存档分类
最新评论
阅读更多

1.HttpServletRequest:
 请求行分为三个部分:请求方式,资源路径和HTTP协议版本,
 1)获取请求行的相关信息的几个重要的方法:
  getMethod():返回请求请求行的请求方法.
  getRequestURI():返回请求行中资源路径的名称,也就是位于端口号之后,参数部分之前的内容.
  getQueryString():返回请求行的参数.如果没有参数则返回空.
  getProtocol():返回请求行中的协议名和版本.
  getContextPath():返回URL所属的web应用程序的路径.
  getPathInfo():返回URL中的额外路径信息.
  getPathTranslated():返回URL中额外路径信息所对应的资源的真实路径.
  getServletPath():返回servlet的名称或servlet所映射的路径.
 2)获取网络连接信息的几个重要的方法:
  getRemoteAddr():返回客户机的IP地址.
  getRemoteHost():返回客户机的主机名.
  getRemotePort():返回客户机的端口.
  getLocalAddr():返回web服务器上接收当前请求的网络接口的IP地址.
  getLocalName():返回web服务器上接收当前请求的网络接口的主机名.
  getLocalPort():返回web服务器上接收当前请求的网络接口的端口.
  getServerName():返回当前请求所连接的服务器的主机名.
  getServerPort():返回当前请求所连接的服务器的端口号.
  getScheme():返回请求的协议名.
  getRequestURL():返回客户端请求的完整URL.
 3)获取请求头信息:
  getHeader():返回指定名称的头字段的值.
  getHeaders():返回指定名称的头字段的值的集合对象.
  getHeaderNames():返回一个包含请求消息中的所有头字段名的集合对象.
  getDateHeader():获取一个指定名称的头字段的值并将其按GMT时间格式转换.
  getContentType():返回Content-Type头字段的值.
  getContentLength():返回Content-Length头字段的值
  getCharacterEncoding():返回请求消息的实体部分的字符集编码.
  4)利用Referer请求头防止"盗链",示例代码如下:
  String referer = request.getHeader("referer");
  String sitePart = "http://" + request.getServerName();
  if(referer != null && referer.startsWith(sitePart)){
   不是"盗链"的处理语句
  }
  else{
   是"盗链"的处理语句 
  }

2.BASE64编码:
 
 /**
  * BASE64编码规则:将一组连续的字节数据按6个bit位进行分组,然后对每组数据用
  * 一个ASICC字符来表示,6个bit位最多能表示2的6次方即64个数值,这64个ASICC字符
  * 就是:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/",
  * 其中每个字符表示的数值就是该字符在上面的排列中对应的索引号,
  * BASE64编码要求在对字节数据按每6个bit位进行分组时,如果不够6位则补"0",
  * 另一条规定就是编码后的结果长度必须是4的整数倍,否则补"=".
  * 下面示例简单实现了BASE64编码.
  */
 import java.io.IOException;
 
 import sun.misc.BASE64Decoder;
 import sun.misc.BASE64Encoder;
 
 public class Base64 {
 
  public static void main(String[] args) throws IOException {
 
   // 定义一个包含64个ASCII字符的字符数组
   final char[] ASCIIARRAY = "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/"
     .toCharArray();
 
   // sun.misc.BASE64Encoder,用于对传入的byte[]数组进行BASE64编码
   BASE64Encoder encoder = new BASE64Encoder();
 
   // 要编码的byte数组
   byte[] srcs = "中华人民共和国".getBytes();
 
   // 编码后的结果
   String afterCode = encoder.encode(srcs);
   System.out.println("使用BASE64Encoder编码:   " + afterCode);
 
   // 定义一个变量存放srcs转换成二进制后的完整字符串
   String total = "";
   for (int src : srcs) {
    // 循环把每个字节转换为二进制.
    String binary = Integer.toBinaryString(src);
 
    // 因为有些英文经过Integer.toBinaryString转换后不够8位,
    // 所以根据实际情况对前面补"0"
    int len = binary.length();
    if (len < 8) {
     for (int i = 0; i < 8 - len; i++) {
      binary = "0" + binary;
     }
    }
 
    // 如果src是负数,那么经过转换的binary就是32个二进制数字,但是一个
    // 字节只有8个二进制数字,所以取出后面8位放进total
    total += binary.substring(binary.length() - 8);
   }
 
   // totalLength为total的长度
   int totalLength = total.length();
 
   // 因为要将一个连续的字节数据按6个bit进行分组,所以定义一个变量检查此字节数据
   // 能不能被6整除,如果不能被6整除则在后面补"0",直到是6的整数倍为止
   int temp = totalLength % 6;
   if (temp != 0) {
    for (int i = 1; i <= 6 - temp; i++) {
     total += "0";
    }
   }
 
   // encoderResult为存放转换的结果
   String encoderResult = "";
 
   for (int i = 0; i < totalLength; i = i + 6) {
    // 循环一次取出6个二进制数,并把其取出来的二进制字符串转换为int型整数
    int index = Integer.parseInt(total.substring(i, i + 6), 2);
    // 把上面取出的整数作为ASCIIARRAY的索引取出对应的字符加到encoderResult中
    encoderResult += ASCIIARRAY[index];
 
   }
 
   // 因为经过BASE64编码后的字符串长度必须是4的整数倍,所以在此对其进行检查,
   // 如果不是4的整数倍就在后面补上"=",直到是4的整数倍为止.
   int n = encoderResult.length() % 4;
   if (n != 0) {
    for (int i = 0; i < 4 - n; i++) {
     encoderResult += "=";
    }
   }
   System.out.println("不使用BASE64Encoder编码: " + encoderResult);
 
   // 使用BASE64Decoder解码对上面编码后的encoderResult解码
   BASE64Decoder decoder = new BASE64Decoder();
   String decoderResult = new String(decoder.decodeBuffer(encoderResult));
   System.out.println("使用BASE64Decoder解码:   " + decoderResult);
  }
 
 }
 
3.Tomcat中的BASE64编码:
 示例代码如下:
 //取出Authorization头字段的值.
 String encoderAuth = request.getHeader("Authorization");
 //要求客户端发送身份认证信息,并且只能是BASIC认证方式.
 if(encoderAuth == null || !encoderAuth.toUpperCase().startsWith("BASIC")){
  response.setStatus(HttpServletResponse.SC_UNAUTHORIZED);
  response.setHeader("WWW-Authenticate","BASIC realm=\"web应用程序的虚拟目录名\"");
  return;
 }
 //对客户端传过来的数据进行BASIC解码
 BASE64Decoder decoder = new BASE64Decoder();
 String decoderResult = new String(decoder.decodeBuffer(encoderAuth.substring(6)));
 String[] info = decoderResult.split(":");
 if(info != null && info.length == 2){
  if(info[0].equals("用户名") && info[1].equals("密码")){
   //用户名和密码正确的处理
  }
  else{
   ////用户名和密码不正确的处理
  }
 }
 else{
  //客户端传递的信息不完整的处理
 } 

分享到:
评论

相关推荐

    scratch少儿编程逻辑思维游戏源码-Pyorovania.zip

    scratch少儿编程逻辑思维游戏源码-Pyorovania.zip

    scratch少儿编程逻辑思维游戏源码-弹力猫.zip

    scratch少儿编程逻辑思维游戏源码-弹力猫.zip

    scratch少儿编程逻辑思维游戏源码-地心引力.zip

    scratch少儿编程逻辑思维游戏源码-地心引力.zip

    基于金枪鱼群优化算法的SVM在多变量时间序列预测中的MATLAB实现及优化

    内容概要:本文介绍了一种基于金枪鱼群优化算法(TSO)和支持向量机(SVM)的混合算法模型——TSO-SVM,在多变量时间序列预测中的应用。文中详细解释了TSO-SVM的工作原理,即通过模拟金枪鱼群觅食行为来优化SVM的参数,从而提升预测性能。同时提供了具体的Matlab代码实现步骤,包括参数初始化、模型训练和预测。实验结果显示,TSO-SVM相较于传统SVM方法,显著提升了预测的准确性和稳定性,并展示了良好的泛化能力。 适合人群:对机器学习尤其是时间序列预测感兴趣的科研人员和技术开发者。 使用场景及目标:①需要进行多变量时间序列预测的研究项目;②希望利用自然启发式优化算法改善现有SVM模型效果的技术团队。 其他说明:推荐使用Libsvm工具箱配合Matlab 2018B及以上版本,仅限于Windows 64位操作系统。

    机器视觉技术:OpenCV与Qt在工业相机采集及图像处理中的应用

    内容概要:本文深入探讨了机器视觉技术,重点介绍了OpenCV和Qt在工业相机采集及图像处理中的应用。文中详细讲述了卡尺工具、找线、找圆、颜色检测、模板匹配及形状匹配等关键技术的具体实现方法,并特别强调了海康工业相机采集与基于形状的模板匹配界面的开发。此外,形状匹配算法已被封装成DLL,方便直接调用。通过实际案例和技术解析,帮助读者全面掌握机器视觉系统的构建。 适合人群:对机器视觉感兴趣的初学者、有一定编程基础的研发人员、从事工业自动化领域的工程师。 使用场景及目标:适用于希望深入了解机器视觉技术及其应用场景的专业人士,旨在提升图像处理能力,优化工业自动化流程,提高生产效率。 其他说明:文章不仅提供理论知识,还附有示例代码,便于读者动手实践并加深理解。

    scratch少儿编程逻辑思维游戏源码-Billy奇妙之旅.zip

    scratch少儿编程逻辑思维游戏源码-Billy奇妙之旅.zip

    电动汽车BMS电池管理系统应用层软件模型:MBD方法、通信协议及AUTOSAR构建

    内容概要:本文详细介绍了基于模型开发(MBD)的BMS电池管理系统应用层软件模型。首先概述了BMS的核心任务,即确保电池的安全与高效运行,涉及充电、放电控制、实时监测和电池均衡管理。接着重点讨论了SUMlink电池管理系统策略模型,该模型通过收集和处理电池的数据(如电压、电流、温度),并运用多种算法(如SOC估算、SOH评估)来优化电池性能。文中还阐述了BMC CVS内部通讯协议DBC的作用,确保各模块间数据传输的准确性与效率。最后,介绍了AUTOSAR标准在BMS系统中的应用,特别是针对MPC5644A芯片的底层Build工程,提高了系统的可维护性、可扩展性和可靠性。此外,提到了INCA A2L标定文件的应用,用于配置和调整系统参数,以满足不同需求。 适合人群:从事电动汽车电池管理系统研究与开发的技术人员,尤其是对MBD方法、通信协议和AUTOSAR标准感兴趣的工程师。 使用场景及目标:适用于希望深入了解BMS系统的设计原理和技术细节的专业人士,旨在提高他们对该领域的理解和实际操作能力。 其他说明:通过对代码的具体分析,读者能够更加直观地理解BMS的工作流程及其各个组件间的协作关系。

    少儿编程scratch项目源代码文件案例素材-深海困境.zip

    少儿编程scratch项目源代码文件案例素材-深海困境.zip

    少儿编程scratch项目源代码文件案例素材-去吧泡泡糖.zip

    少儿编程scratch项目源代码文件案例素材-去吧泡泡糖.zip

    KEPServerEX6-6.17.269.0

    KEPServerEX6-6.17.269.0,最新版

    scratch少儿编程逻辑思维游戏源码-第二个循环.zip

    scratch少儿编程逻辑思维游戏源码-第二个循环.zip

    少儿编程scratch项目源代码文件案例素材-手里剑.zip

    少儿编程scratch项目源代码文件案例素材-手里剑.zip

    少儿编程scratch项目源代码文件案例素材-山地跳跃.zip

    少儿编程scratch项目源代码文件案例素材-山地跳跃.zip

    机器人路径规划中Informed RRT*算法详解与代码实现

    内容概要:本文详细介绍了Informed RRT*算法及其在机器人路径规划领域的应用。文章首先解释了该算法相较于传统RRT*算法的优势,即通过将采样范围限制在由起点和终点构成的椭圆区域内来提高搜索效率。接着,文中提供了具体的代码实现,包括椭圆采样的核心公式、路径优化的rewire步骤以及动态调整邻居半径的方法。此外,还讨论了路径队列管理和椭圆区域随路径优化动态更新的重要性。通过这些技术手段,Informed RRT*能够在找到初始路径后显著加快优化速度。 适合人群:对机器人路径规划感兴趣的科研人员、工程师及学生。 使用场景及目标:适用于需要高效路径规划的实际应用场景,如自动驾驶汽车、无人机飞行路径规划等。目标是在复杂环境中快速找到从起点到终点的最佳路径。 其他说明:建议读者在理解理论的基础上,结合提供的代码进行实验,以便更好地掌握算法的工作机制。同时,在不同环境条件下测试算法性能,观察其自适应能力。

    基于COMSOL有限元仿真的变压器辐射传热数值分析:从入门到进阶

    内容概要:本文详细介绍了基于COMSOL有限元软件的变压器辐射传热数值分析方法。首先,解释了变压器内外辐射传热的基本机理,包括热量通过传导、对流和辐射的方式传递,重点在于辐射传热的作用及其数学描述。接着,逐步引导读者从零开始构建有限元仿真模型,涵盖模型参数确定、网格划分、材料属性定义、边界条件设置、传热方程设定、仿真运行及结果分析等多个步骤。最后,探讨了进一步研究的方向,如不同因素(温度、材料属性、几何形状)对辐射传热的影响,以及该模型在电力电子设备和热管理系统的潜在应用。 适合人群:电气工程专业学生、初学者和技术爱好者,尤其是对有限元仿真和变压器辐射传热感兴趣的群体。 使用场景及目标:适用于希望通过实际操作掌握有限元仿真技能的人群,旨在帮助他们理解变压器辐射传热机制并能独立完成相关仿真项目。 其他说明:本文不仅提供了理论知识,还附带了详细的视频教程和仿真模型,使学习过程更加直观易懂。

    scratch少儿编程逻辑思维游戏源码-Scratch 奔跑.zip

    scratch少儿编程逻辑思维游戏源码-Scratch 奔跑.zip

    scratch少儿编程逻辑思维游戏源码-超级马里奥兄 回放引擎.zip

    scratch少儿编程逻辑思维游戏源码-超级马里奥兄 回放引擎.zip

    少儿编程scratch项目源代码文件案例素材-你准备好了吗?.zip

    少儿编程scratch项目源代码文件案例素材-你准备好了吗?.zip

    少儿编程scratch项目源代码文件案例素材-潜水艇.zip

    少儿编程scratch项目源代码文件案例素材-潜水艇.zip

    基于Python的两电平三相并网逆变器有限控制集模型预测控制(FCS-MPC)实现及波形分析

    内容概要:本文详细介绍了如何利用Python实现两电平三相并网逆变器的有限控制集模型预测控制(FCS-MPC)。首先建立了逆变器的数学模型,接着探讨了预测控制的核心思想,即通过遍历所有可能的开关状态选择最优解。文中给出了具体的代码实现步骤,包括系统模型建立、开关状态枚举、代价函数设计以及完整的控制循环流程。此外,还讨论了仿真过程中可能出现的问题及其解决方法,如电感参数不准确、延时补偿不足等,并提供了提高控制精度的小技巧。 适合人群:具有一定编程基础并对电力电子控制系统感兴趣的工程师和技术爱好者。 使用场景及目标:适用于希望深入了解FCS-MPC原理并在实践中掌握其实现方法的人群。通过本教程的学习,读者能够独立完成从建模到仿真的全过程,最终获得理想的电流电压波形。 其他说明:文章强调了实际调试中的注意事项,如坐标变换的选择、延时补偿的重要性、代价函数的设计等,这些都是确保控制效果的关键因素。同时指出,在某些情况下,经验性的调整可能会比严格的理论计算带来更好的效果。

Global site tag (gtag.js) - Google Analytics