关于JSTL和EL常用标签的初识,Md5代码尝试,上课笔记

来源:互联网 发布:数据库完整性约束类型 编辑:程序博客网 时间:2024/05/29 08:57
1.EL:<%pageContext.setAttribute("aa", 121);%>
1.${30 }<!-- 常量 -->输出30
2. ${30+50}<!-- 运算-->输出80
3. ${NULL } <!-- 空-->无输出
4.${"JJJK" } <!-- 字符串-->输出30
5.${ aa} <!-- 传值-->输出121
6.$ { } 输出${}
7.${empty(aa)}输出false<!-- empty 判断是否有值,有为false,否则为true-->
  ${empty null }输出true
  ${empty "" }输出true
                8.<% 
  User user=new User();
  List<User> userlist=new ArrayList<User>();
  userlist.add(new User());//注意有无这句代码的区别;
  pageContext.setAttribute("userlist",userlist);
  
  %>
  ${empty userlist }有以上代码输出false(即代表有值),否则为true
               9.<%
  pageContext.setAttribute("pass","123456"); 
  pageContext.setAttribute("pass1","123456");
  %>
  ${pass==pass1 }输出true
                 pageContext.setAttribute("pass","123456"); 
  pageContext.setAttribute("pass1","111222");
  %>
  ${pass==pass1 }输出false
el表达式的另外一种形式:${object.attribute.attribute}或者${objiect["attribute"]["attribute"]}
   ${requestScope.user }${sessionScope.user }
   ${作用域(例如:sessionScope).用户名}//获取该作用域下的值,不然从page→request→session→application层层访问
2.JSTL:jsp standard tag library —jsp标准标签库:core,i18n,sql,xml,functions等包
   <c:if >:
          <%@ taglib prefix="c" uri="http://java.sun.com/jsp/jstl/core" %>
          <c:if test="${1==1}">
            1==1
            </c:if>
             <c:if test="${1!=1}">
              1!=1   输出1==1
              </c:if>
    <c:foreach> 


    <c:chose>
      <% int a=(int)(Math.random()*4);
   pageContext.setAttribute("a",a);
 %>
 <c:choose>
    <c:when test="${a==1}">
      产生的随机数是1
    </c:when>
    <c:when test="${a==2}">
      产生的随机数是2
    </c:when>
    <c:when test="${a==3}">
      产生的随机数是3
    </c:when>
    <c:when test="${a==4}">//这个标签可以有多个
      产生的随机数是14
    </c:when>
    <c:otherwise>
       rrr
    </c:otherwise>//这个标签只能有一个
 </c:choose>


3.Message Digest Algorithm MD5(中文名为消息摘要算法第五版)为计算机安全领域广泛使用的一种散列函数,用以提供消息的完整性保护。该算法的文件号为RFC 1321(R.Rivest,MIT Laboratory for Computer Science and RSA Data Security Inc. April 1992)。
MD5即Message-Digest Algorithm 5(信息-摘要算法5),用于确保信息传输完整一致。是计算机广泛使用的杂凑算法之一(又译摘要算法、哈希算法),主流编程语言普遍已有MD5实现。将数据(如汉字)运算为另一固定长度值,是杂凑算法的基础原理,MD5的前身有MD2、MD3和MD4。
MD5算法具有以下特点:
1、压缩性:任意长度的数据,算出的MD5值长度都是固定的。
2、容易计算:从原数据计算出MD5值很容易。
3、抗修改性:对原数据进行任何改动,哪怕只修改1个字节,所得到的MD5值都有很大区别。
4、强抗碰撞:已知原数据和其MD5值,想找到一个具有相同MD5值的数据(即伪造数据)是非常困难的。

MD5的作用是让大容量信息在用数字签名软件签署私人密钥前被"压缩"成一种保密的格式(就是把一个任意长度的字节串变换成一定长的十六进制数字串)。除了MD5以外,其中比较有名的还有sha-1、RIPEMD以及Haval等。

4.Md5加密 Md5Util.java 可将最后的到的数据存入数据库

package com.jkx.util;import java.security.MessageDigest;public class Md5Util {public   final   static  String MD5(String s) {    char  hexDigits[] = {  '0' ,  '1' ,  '2' ,  '3' ,  '4' ,  '5' ,  '6' ,  '7' ,  '8' ,  '9' ,      'a' ,  'b' ,  'c' ,  'd' ,  'e' ,  'f'  };    try  {     byte [] strTemp = s.getBytes();     MessageDigest mdTemp = MessageDigest.getInstance("MD5" );     mdTemp.update(strTemp);     byte [] md = mdTemp.digest();     int  j = md.length;     char  str[] =  new   char [j *  2 ];     int  k =  0 ;     for  ( int  i =  0 ; i < j; i++) {      byte  byte0 = md[i];      str[k++] = hexDigits[byte0 >>> 4  &  0xf ];      str[k++] = hexDigits[byte0 & 0xf ];     }     return   new  String(str);    } catch  (Exception e) {     return   null ;    }   }     public   static   void  main(String[] args) {    // MD5_Test aa = new MD5_Test();     System.out.print(Md5Util.MD5("b" ));   }  }
Md5Util2

package com.jkx.util;import java.security.MessageDigest;public class Md5Util2 { // MD5加码。32位    public   static  String MD5(String inStr) {    MessageDigest md5 = null ;    try  {     md5 = MessageDigest.getInstance("MD5" );    } catch  (Exception e) {     System.out.println(e.toString());     e.printStackTrace();     return   "" ;    }    char [] charArray = inStr.toCharArray();    byte [] byteArray =  new   byte [charArray.length];      for  ( int  i =  0 ; i < charArray.length; i++)     byteArray[i] = (byte ) charArray[i];      byte [] md5Bytes = md5.digest(byteArray);      StringBuffer hexValue = new  StringBuffer();      for  ( int  i =  0 ; i < md5Bytes.length; i++) {     int  val = (( int ) md5Bytes[i]) &  0xff ;     if  (val <  16 )      hexValue.append("0" );     hexValue.append(Integer.toHexString(val));    }      return  hexValue.toString();   }     // 可逆的加密算法    public   static  String KL(String inStr) {    // String s = new String(inStr);     char [] a = inStr.toCharArray();    for  ( int  i =  0 ; i < a.length; i++) {     a[i] = (char ) (a[i] ^  't' );    }    String s = new  String(a);    return  s;   }     // 加密后解密    public   static  String JM(String inStr) {    char [] a = inStr.toCharArray();    for  ( int  i =  0 ; i < a.length; i++) {     a[i] = (char ) (a[i] ^  't' );    }    String k = new  String(a);    return  k;   }      // 测试主函数    public   static   void  main(String args[]) {    String s = new  String( "B" );    System.out.println("原始:"  + s);    System.out.println("MD5后:"  + MD5(s));    System.out.println("MD5后再加密:"  + KL(MD5(s)));    System.out.println("解密为MD5后的:"  + JM(KL(MD5(s))));   }  }



原创粉丝点击