几个很有用的类和方法封装

一:实现密码的加密:

import java.security.MessageDigest;

public final class MD5 {


public final static String encode(String str) {
StringBuffer buf = new StringBuffer();
try {
MessageDigest md5 = MessageDigest.getInstance("MD5");
md5.update(str.getBytes());
byte[] bytes = md5.digest();
for (int i = 0; i < bytes.length; ++i) {
String s = Integer.toHexString(bytes[i] & 0xFF);
if (s.length() == 1) {
buf.append("0");
}
buf.append(s);
}
} catch (Exception localException) {
}

return buf.toString();
}
二:判断是否是整数:
public class ParUtile {
//判断是否是整数的正则表达式
public static boolean isNumber(String key){
if(key != null && key.length() > 0){
return key.matches("^[0-9]+$");

}else{
return false;
}

}
}
三:对一些html标签进行过滤,防止脚本攻击:
public final class SecHtmlUtils {


public static String htmltostr(String temp){
temp = temp.replaceAll("<","<");
temp = temp.replaceAll("'","&");
temp = temp.replaceAll("\"",""");
return temp = temp.replaceAll(">","&gt");

}
public static void main(String[] args){
System.out.println(SecHtmlUtils.htmltostr("<script>alert(ok)</script>"));

}
}
四.实现对数据库更新和查询的方法封装:
1.实现更新(修改,删除,添加)
public static boolean update(String sql, Object[] param) {
Connection conn = null;
PreparedStatement stmt = null;
int rs = 0;
try {
conn = getConnection();
stmt = conn.prepareStatement(sql);
param(stmt, param);
rs = stmt.executeUpdate();
} catch (SQLException e) {
e.printStackTrace();
} finally {
close(null, stmt, conn);
}

return rs != 0;

}
2.实现查询:
public static List<String[]> query(String sql,Object [] param){
Connection conn = null;
PreparedStatement stmt = null;
ResultSet rs = null;
ResultSetMetaData mate = null;
List<String[]> list = new ArrayList<String[]>();
try{
conn = SQLHelper.getConnection();
stmt = conn.prepareStatement(sql);
param(stmt,param);

rs= stmt.executeQuery();
mate=stmt.getMetaData();
int count = mate.getColumnCount();
while(rs.next()){
String[] arr = new String[count];
for(int i=1;i<arr.length;i++){
arr[i-1]=rs.getString(i);

}
list.add(arr);
}
}catch(Exception e){
e.printStackTrace();

}finally{
SQLHelper.close(rs, stmt, conn);
}

return list;
}
3.在上面的方法中都调用了同一个方法,因为代码块相同,不必写多次,所以有写成了一个方法,直接调用即可:
private static void param(PreparedStatement stmt,Object[] param){
if(param != null){
//i=0 4:: 0 1 2 3
//info.getName() java.lang.String
//java.lang.String
try{
for(int i = 0 ; i < param.length;i++){
if(param[i].getClass() == java.lang.Integer.class){
stmt.setInt(i+1, (Integer)param[i]);
}else if(param[i].getClass() == java.lang.String.class){
stmt.setString(i+1, (String)param[i]);
}else if(param[i].getClass() == java.util.Date.class){

stmt.setTimestamp(i+1, conDD((java.util.Date)param[i]));
}

}
}catch(Exception e){
e.printStackTrace();
}

}
}
在上面的类和方法中使用的时候可以直接调用,这样大大减少了很多的代码量,也提高了编程的效率,也提高了代码的复用率。特别是那个两个对数据库操作的方法中,需要修改,添加删除,查询时,只需写操作的sql语句,传进相应的参数即可使用,避免了每一次操作数据库都要写很多的东西。
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值