您的位置:首页 > Web前端 > JavaScript

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

2017-09-13 16:50 447 查看
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、强抗碰撞:已知原数据和其
9bfc
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))));
}
}
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: