欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

MyBatis自定義類型轉換器實現(xiàn)加解密

 更新時間:2016年07月22日 10:55:57   作者:nz360  
這篇文章主要介紹了MyBatis自定義類型轉換器實現(xiàn)加解密的相關資料,需要的朋友可以參考下

需求場景:當數(shù)據(jù)庫中保存的部分數(shù)據(jù)需要加密,頁面需要正常顯示時。這是就需要我們自定義類型轉換器,在Mybatis執(zhí)行SQL得到結果時,通過自定義類型轉換器將CHAR或者VARCHAR2進行加解密處理,Java代碼如下:

/**自定義typeHandler<br/> 
* 1 插入數(shù)據(jù)庫, 加密 
* 2 查詢,解密 
* @author Administrator 
* 
*/ 
public class CryptTypeHandler implements TypeHandler<CryptType> { 
public CryptType getResult(ResultSet rs, String columnName) throws SQLException { 
String value=""; 
CryptType v=new CryptType(value); 
value=rs.getString(columnName); 
if(value!=null){ 
value=decrypt(value.toString()); 
v.setValue(value); 
} 
return v; 
} 
public CryptType getResult(ResultSet rs, int columnIndex) throws SQLException { 
String value=""; 
CryptType v=new CryptType(value); 
value =rs.getString(columnIndex); 
if(value!=null){ 
v.setValue(value); 
} 
return v; 
} 
public CryptType getResult(CallableStatement cs, int columnIndex) throws SQLException { 
String value=""; 
CryptType v=new CryptType(); 
value =cs.getString(columnIndex); 
if(value!=null){ 
v.setValue(value); 
} 
return v; 
} 
public void setParameter(PreparedStatement ps, int i, CryptType parameter, JdbcType arg3) throws SQLException { 
String value=""; 
if(parameter!=null && parameter.toString()!=null){ 
value=encrypt(parameter.toString()); 
} 
ps.setString(i, value.toString()); 
} 
/**插入數(shù)據(jù)庫 
* @param value 
* @return 
*/ 
private String encrypt(String value) { 
value=CryptUtils.encrypt(value); 
return value; 
} 
/** 從數(shù)據(jù)庫讀出 
* @param value 
* @return 
*/ 
private String decrypt(String value){ 
value=CryptUtils.decrypt(value); 
return value; 
} 
}

自定義類型

import java.io.Serializable; 
/** 
* 自定義類型 
* 定義為該類型的實體屬性會走CryptTypeHandler.java做加解密處理 
* 
* @author yy 
* 
*/ 
public class MyString implements Serializable, CharSequence, Comparable<String>{ 
private static final long serialVersionUID = 1L; 
private String value; 
public MyString (){ 
} 
public CryptType(String value){ 
this.value=value; 
} 
public String getValue() { 
return value; 
} 
public void setValue(String value) { 
this.value = value; 
} 
public int compareTo(String arg0) { 
// TODO Auto-generated method stub 
return 0; 
} 
public char charAt(int arg0) { 
// TODO Auto-generated method stub 
return 0; 
} 
public int length() { 
// TODO Auto-generated method stub 
return 0; 
} 
public CharSequence subSequence(int arg0, int arg1) { 
// TODO Auto-generated method stub 
return null; 
} 
@Override 
public String toString() { 
return value; 
} 
} 

mybatis自定義類型配置

<!-- 自定義類型 --> 
<typeHandlers> 
<typeHandler javaType="com.***.MyString" handler="com.***.MyTypeHandler"/> 
</typeHandlers>

實體中使用

public class LoanEnterprise{ 
private MyString name; 
//注意: 
//如果頁面有查詢條件也被加密時,mybatis sql中的條件判斷會無法匹配,暫時的一種解決辦法是在 
public CryptType getName() { 
if(name!=null && name.getValue().equals("")){ 
return null; 
}else { 
return name; 
} 
} 
public void setName(CryptType name) { 
this.name = name; 
} 
} 

以上所述是小編給大家介紹的MyBatis自定義類型轉換器實現(xiàn)加解密,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復大家的。在此也非常感謝大家對腳本之家網站的支持!

相關文章

  • java中實現(xiàn)map與對象相互轉換的幾種實現(xiàn)

    java中實現(xiàn)map與對象相互轉換的幾種實現(xiàn)

    這篇文章主要介紹了java中實現(xiàn)map與對象相互轉換的幾種實現(xiàn),文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2020-07-07
  • Java的JSTL標簽庫詳解

    Java的JSTL標簽庫詳解

    JSTL包含用于編寫和開發(fā)JSP頁面的一組標準標簽,它可以為用戶提供一個無腳本環(huán)境。在此環(huán)境中,用戶可以使用標簽編寫代碼,而無須使用Java腳本
    2023-05-05
  • java導出excel 瀏覽器直接下載或者或以文件形式導出

    java導出excel 瀏覽器直接下載或者或以文件形式導出

    這篇文章主要介紹了java導出excel 瀏覽器直接下載或者或以文件形式導出方式,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2021-06-06
  • Java線程中的關鍵字和方法示例詳解

    Java線程中的關鍵字和方法示例詳解

    這篇文章主要介紹了Java有關線程中的關鍵字和方法,本文通過示例代碼給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2022-03-03
  • JAVA的LIST接口的REMOVE重載方法調用原理解析

    JAVA的LIST接口的REMOVE重載方法調用原理解析

    這篇文章主要介紹了JAVA的LIST接口的REMOVE重載方法調用原理解析,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友可以參考下
    2019-10-10
  • java讀取文件字符集示例方法

    java讀取文件字符集示例方法

    這篇文章主要介紹了java讀取文件字符集的示例,需要的朋友可以參考下
    2014-02-02
  • SpringBoot整合Shiro的方法詳解

    SpringBoot整合Shiro的方法詳解

    Apache?Shiro是一個java安全(權限)框架,Shiro可以非常容易的開發(fā)出足夠好的應用,其不僅可以用在javase環(huán)境,也可以用在javaee環(huán)境。本文介紹了SpringBoot整合Shiro的方法,需要的可以參考一下
    2022-05-05
  • 淺析Java Web錯誤/異常處理頁面

    淺析Java Web錯誤/異常處理頁面

    這篇文章主要和大家一起對Java Web錯誤/異常處理頁面進行分析研究,感興趣的小伙伴們可以參考一下
    2016-03-03
  • SpringCloud將Nacos作為配置中心實現(xiàn)流程詳解

    SpringCloud將Nacos作為配置中心實現(xiàn)流程詳解

    這篇文章主要介紹了Springcloud中的Nacos Config服務配置,本文以用戶微服務為例,進行統(tǒng)一的配置,結合實例代碼給大家介紹的非常詳細,需要的朋友可以參考下
    2022-10-10
  • Java線程池使用AbortPolicy策略

    Java線程池使用AbortPolicy策略

    這篇文章主要介紹了?Java線程池使用AbortPolicy策略,文章圍繞主題展開詳細的內容介紹,具有一定的參考價值,感興趣的小伙伴可以參考一下
    2022-06-06

最新評論