国产xxxx99真实实拍_久久不雅视频_高清韩国a级特黄毛片_嗯老师别我我受不了了小说

資訊專欄INFORMATION COLUMN

excel導入時身份證號異常以及解決

cyixlq / 4458人閱讀

摘要:之后因為身份證中也可能含有字母所以解決方法改為將單元格的類型設置為文本類型。解決報錯固定保存的長度時,就不會產生第一個異常了。身份證長度為十八位返回前臺僅支持寫入輸出時,將忽略掉該字段并不存在數據表中只用于前臺使用

問題描述

在導入學生信息的時候發現導入成功之后結果顯示是錯誤的,錯誤如下所示

剛開始的時候只是感覺是ID card出得問題,但是并沒有明白具體的什么地方出得問題,下面是我們導入的示例信息,然后我們點開數據庫看了一下我們數據庫里的值,發現并不是我們導入的值,而是2147483647然后Google了一下這個數字,發現如下

然后感覺是不是數據類型導致的問題,于是看了一下源碼發現如下,當前我們的單元格默認為數字,然后按照數字進行處理,結果因為身份證的數字太大,導致導致int無法保存。

之后因為身份證中也可能含有字母所以解決方法改為將單元格的類型設置為文本類型。

更改單元格格式為文本

再設置單元格類型的時候由于我們使用的是導出模版原來是按照Java通過代碼生成的,改的時候感覺很麻煩,而且之后考慮到還要為模版添加示例數據,更改樣式之類的操作,如果一直使用Java的代碼生成的化,會很費事,于是將導出模版的功能更改為直接導出一個模版的靜態文件,之后當我們的模版需要更改的時候我們只需要手動更改excel就行,感覺這樣會方便很多。

為什么非18位的身份證可以保存

因為我記得字段是加了長度限制的,之后在源碼中看了一下,發現之前的寫法如下:

@Column(length = 18)
private String idCardNumber;

更該之后的代碼,可以使用@Size或@Length:

@Size(min = 18, max = 18)
private String idCardNumber;

@Length(min = 18, max = 18)
private String idCardNumber;

@Size,@Longth和@Column(length = value)之間的差異

處理warn錯誤


最開始一直不清楚為什么會出錯,一直找不到錯誤原因是什么,之后問了一下喜碩,他幫我找了一下發現錯誤原因是如下,更改了idcard的get方法:

public String getIdCardNumber() {
    // 獲取身份證時將身份證加密
    StringBuffer encryptIdCardNumber = new StringBuffer(idCardNumber);
    encryptIdCardNumber.replace(6, idCardNumber.length() - 6, "******");
    return encryptIdCardNumber.toString();
}

第一處是因為當身份證長度小于12位是替換中間位數位*的方法會報錯,因為替換的start大于了end

第二處是猜測是因為在yunzhiRepository中會默認的調用student的屬性,有些時候屬性是不全的會導致空指針異常。

解決warn報錯

@Size固定保存的長度時,就不會產生第一個異常了。

加上idcard為空的判斷,如果為空之前返回idcard。

實現方法改進

新增一個字段用于前臺的顯示,并設置原字段為只可寫的字段,新生成字段只是讀取原身份證字段,但不保存到數據庫中,實現方式如下。

/**
 * 身份證 長度為十八位 返回前臺
 * 僅支持json寫入,json輸出時,將忽略掉
 */
@Size(min = 18, max = 18)
@JsonProperty(access = JsonProperty.Access.WRITE_ONLY)
private String idCardNumber;

/**
 * 該字段并不存在數據表中,只用于前臺使用
 */
@Transient
private String idCardNumberForShow;

public String getIdCardNumberForShow() {
        if (idCardNumber != null) {
            StringBuffer encryptIdCardNumber = new StringBuffer(idCardNumber);
            encryptIdCardNumber.replace(6, idCardNumber.length() - 6, "******");
            return encryptIdCardNumber.toString();
        } else {
            return "";
        }
    }

@Deprecated
private void setIdCardNumberForShow(String idCardNumberForShow) {}

文章版權歸作者所有,未經允許請勿轉載,若此文章存在違規行為,您可以聯系管理員刪除。

轉載請注明本文地址:http://specialneedsforspecialkids.com/yun/77595.html

相關文章

  • 用python庫openpyxl操作excel,從源excel表中提取信息復制到目標excel表中

    摘要:特別注意當用模式載入時,跟都是對象。可以使用載入已經存在的表。我們的目的是從源表中提取信息并批量復制到目標表中,所以我們首先定義一些變量。最后保存目標就可以了。 現代生活中,我們很難不與excel表打交道,excel表有著易學易用的優點,只是當表中數據量很大,我們又需要從其他表冊中復制粘貼一些數據(比如身份證號)的時候,我們會越來越倦怠,畢竟我們不是機器,沒法長時間做某種重復性的枯燥操...

    gaosboy 評論0 收藏0
  • 使用js-xlsx純前端導出excel

    摘要:前言最近公司需要將幾張統計表格導出到由于公司現有導出功能是前后端配合的導出,覺得麻煩,所以想找一個純前端導出的工具,最后找到了,評價還是挺高的,但是中文文檔沒找到百度也沒有找到一個比較全面的教程所以踩了很多坑,自己記錄下,方便以后使用。 前言 最近公司需要將幾張統計表格導出到excel,由于公司現有導出excel功能是前后端配合的導出,覺得麻煩,所以想找一個純前端導出的工具,最后找到了...

    Cheriselalala 評論0 收藏0
  • 使用js-xlsx純前端導出excel

    摘要:前言最近公司需要將幾張統計表格導出到由于公司現有導出功能是前后端配合的導出,覺得麻煩,所以想找一個純前端導出的工具,最后找到了,評價還是挺高的,但是中文文檔沒找到百度也沒有找到一個比較全面的教程所以踩了很多坑,自己記錄下,方便以后使用。 前言 最近公司需要將幾張統計表格導出到excel,由于公司現有導出excel功能是前后端配合的導出,覺得麻煩,所以想找一個純前端導出的工具,最后找到了...

    inapt 評論0 收藏0
  • 使用js-xlsx純前端導出excel

    摘要:前言最近公司需要將幾張統計表格導出到由于公司現有導出功能是前后端配合的導出,覺得麻煩,所以想找一個純前端導出的工具,最后找到了,評價還是挺高的,但是中文文檔沒找到百度也沒有找到一個比較全面的教程所以踩了很多坑,自己記錄下,方便以后使用。 前言 最近公司需要將幾張統計表格導出到excel,由于公司現有導出excel功能是前后端配合的導出,覺得麻煩,所以想找一個純前端導出的工具,最后找到了...

    LeanCloud 評論0 收藏0

發表評論

0條評論

最新活動
閱讀需要支付1元查看
<