成人国产在线小视频_日韩寡妇人妻调教在线播放_色成人www永久在线观看_2018国产精品久久_亚洲欧美高清在线30p_亚洲少妇综合一区_黄色在线播放国产_亚洲另类技巧小说校园_国产主播xx日韩_a级毛片在线免费

資訊專欄INFORMATION COLUMN

excel導(dǎo)入時(shí)身份證號(hào)異常以及解決

cyixlq / 4555人閱讀

摘要:之后因?yàn)樯矸葑C中也可能含有字母所以解決方法改為將單元格的類型設(shè)置為文本類型。解決報(bào)錯(cuò)固定保存的長(zhǎng)度時(shí),就不會(huì)產(chǎn)生第一個(gè)異常了。身份證長(zhǎng)度為十八位返回前臺(tái)僅支持寫入輸出時(shí),將忽略掉該字段并不存在數(shù)據(jù)表中只用于前臺(tái)使用

問題描述

在導(dǎo)入學(xué)生信息的時(shí)候發(fā)現(xiàn)導(dǎo)入成功之后結(jié)果顯示是錯(cuò)誤的,錯(cuò)誤如下所示

剛開始的時(shí)候只是感覺是ID card出得問題,但是并沒有明白具體的什么地方出得問題,下面是我們導(dǎo)入的示例信息,然后我們點(diǎn)開數(shù)據(jù)庫看了一下我們數(shù)據(jù)庫里的值,發(fā)現(xiàn)并不是我們導(dǎo)入的值,而是2147483647然后Google了一下這個(gè)數(shù)字,發(fā)現(xiàn)如下

然后感覺是不是數(shù)據(jù)類型導(dǎo)致的問題,于是看了一下源碼發(fā)現(xiàn)如下,當(dāng)前我們的單元格默認(rèn)為數(shù)字,然后按照數(shù)字進(jìn)行處理,結(jié)果因?yàn)樯矸葑C的數(shù)字太大,導(dǎo)致導(dǎo)致int無法保存。

之后因?yàn)樯矸葑C中也可能含有字母所以解決方法改為將單元格的類型設(shè)置為文本類型。

更改單元格格式為文本

再設(shè)置單元格類型的時(shí)候由于我們使用的是導(dǎo)出模版原來是按照J(rèn)ava通過代碼生成的,改的時(shí)候感覺很麻煩,而且之后考慮到還要為模版添加示例數(shù)據(jù),更改樣式之類的操作,如果一直使用Java的代碼生成的化,會(huì)很費(fèi)事,于是將導(dǎo)出模版的功能更改為直接導(dǎo)出一個(gè)模版的靜態(tài)文件,之后當(dāng)我們的模版需要更改的時(shí)候我們只需要手動(dòng)更改excel就行,感覺這樣會(huì)方便很多。

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

因?yàn)槲矣浀米侄问羌恿碎L(zhǎng)度限制的,之后在源碼中看了一下,發(fā)現(xiàn)之前的寫法如下:

@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錯(cuò)誤


最開始一直不清楚為什么會(huì)出錯(cuò),一直找不到錯(cuò)誤原因是什么,之后問了一下喜碩,他幫我找了一下發(fā)現(xiàn)錯(cuò)誤原因是如下,更改了idcard的get方法:

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

第一處是因?yàn)楫?dāng)身份證長(zhǎng)度小于12位是替換中間位數(shù)位*的方法會(huì)報(bào)錯(cuò),因?yàn)樘鎿Q的start大于了end

第二處是猜測(cè)是因?yàn)樵趛unzhiRepository中會(huì)默認(rèn)的調(diào)用student的屬性,有些時(shí)候?qū)傩允遣蝗臅?huì)導(dǎo)致空指針異常。

解決warn報(bào)錯(cuò)

@Size固定保存的長(zhǎng)度時(shí),就不會(huì)產(chǎn)生第一個(gè)異常了。

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

實(shí)現(xiàn)方法改進(jìn)

新增一個(gè)字段用于前臺(tái)的顯示,并設(shè)置原字段為只可寫的字段,新生成字段只是讀取原身份證字段,但不保存到數(shù)據(jù)庫中,實(shí)現(xiàn)方式如下。

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

/**
 * 該字段并不存在數(shù)據(jù)表中,只用于前臺(tái)使用
 */
@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) {}

文章版權(quán)歸作者所有,未經(jīng)允許請(qǐng)勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。

轉(zhuǎn)載請(qǐng)注明本文地址:http://systransis.cn/yun/77595.html

相關(guān)文章

  • 用python庫openpyxl操作excel,從源excel表中提取信息復(fù)制到目標(biāo)excel表中

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

    gaosboy 評(píng)論0 收藏0
  • 使用js-xlsx純前端導(dǎo)出excel

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

    Cheriselalala 評(píng)論0 收藏0
  • 使用js-xlsx純前端導(dǎo)出excel

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

    inapt 評(píng)論0 收藏0
  • 使用js-xlsx純前端導(dǎo)出excel

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

    LeanCloud 評(píng)論0 收藏0

發(fā)表評(píng)論

0條評(píng)論

最新活動(dòng)
閱讀需要支付1元查看
<