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值的数据(即伪造数据)是非常困难的。
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))));
}
}