参数含有下划线开头无法正确传参问题

现象:

定义如下参数:

使用post传参:

 传递参数如下:

{"docName":"0290bf3bf9174f37a8984915d396fa94.png","examDate":"2022-01-12 00:00:00","examType":"4","examUserId":"1353881183645077506","examUserName":"科技科账号","examUserOrgId":"1243469076374843394","villageOid":"1384688","files":[{"docOid":"1497096946099105794","fileOid":"202202d35174f418a5447a8d7c918b6af2156a","fileUrl":"0290bf3bf9174f37a8984915d396fa94.png","name":"202202d35174f418a5447a8d7c918b6af2156a","url":"0290bf3bf9174f37a8984915d396fa94.png","uid":1646030867386,"status":"success"},{"fileOid":"2022021f1534d292c34ef5bf5a74519b204525","fileUrl":"Capture001.png","name":"2022021f1534d292c34ef5bf5a74519b204525","url":"Capture001.png","uid":1646030874168,"status":"success"}],"isSave":false,"_fileIds":"202202d35174f418a5447a8d7c918b6af2156a,2022021f1534d292c34ef5bf5a74519b204525","_fileUrls":"0290bf3bf9174f37a8984915d396fa94.png,Capture001.png"}

 此字段有对应值。

但是通过postman进行测试时会发现_fileIds和_fileUrls无法正确获取到对应值。

现象如下:

 其他测试:

输入:

{"_fileIds":"202202d35174f418a5447a8d7c918b6af2156a,2022021f1534d292c34ef5bf5a74519b204525",
"_fileUrls":"0290bf3bf9174f37a8984915d396fa94.png,Capture001.png"}

现象:

 输入:

{"__fileIds":"202202d35174f418a5447a8d7c918b6af2156a,2022021f1534d292c34ef5bf5a74519b204525",
"_fileUrls":"0290bf3bf9174f37a8984915d396fa94.png,Capture001.png"}

 具体原因不明。

========================================================================

怀疑一:json转化问题。

怀疑二:代码做了相应转化。

========================================================================

进行问题排查:

方向一:在过滤器和拦截器处设置断点,查看在过滤器和拦截器处是否正常传参。

下面的方法可以获取body参数:

    //通过request.getReader()的方式来获取body
    public static String getBodyMsg(HttpServletRequest request)
       {
    
           BufferedReader br = null;
           StringBuilder sb = new StringBuilder("");
           try
           {
               br = request.getReader();
               String str;
               while ((str = br.readLine()) != null)
               {
                   sb.append(str);
               }
               br.close();
           }
           catch (IOException e)
           {
               e.printStackTrace();
           }
           finally
           {
               if (null != br)
               {
                   try
                   {
                       br.close();
                   }
                   catch (IOException e)
                   {
                       e.printStackTrace();
                   }
               }
           }
           return sb.toString();
       }

经验证参数正常。

方向二:验证body参数转相应对象参数是否正确。

经跟踪确认,代码使用com.alibaba.fastjson.JSON.parseObject这个方法将body参数转成对应的对象,于是拿到对应版本的Jar包,进行测试。

获取jar包版本:

 进行测试:

package testDay01;

import java.util.Arrays;
import java.util.Date;

public class ttq {
	private String oid;

    private String docName;

    private String villageOid;

    private Date examDate;

    private String examType;

    private String fileIds;
    private String fileUrls;

    private String[] _fileIds;
    private String[] _fileUrls;
	public String getOid() {
		return oid;
	}
	public void setOid(String oid) {
		this.oid = oid;
	}
	public String getDocName() {
		return docName;
	}
	public void setDocName(String docName) {
		this.docName = docName;
	}
	public String getVillageOid() {
		return villageOid;
	}
	public void setVillageOid(String villageOid) {
		this.villageOid = villageOid;
	}
	public Date getExamDate() {
		return examDate;
	}
	public void setExamDate(Date examDate) {
		this.examDate = examDate;
	}
	public String getExamType() {
		return examType;
	}
	public void setExamType(String examType) {
		this.examType = examType;
	}
	public String getFileIds() {
		return fileIds;
	}
	public void setFileIds(String fileIds) {
		this.fileIds = fileIds;
	}
	public String getFileUrls() {
		return fileUrls;
	}
	public void setFileUrls(String fileUrls) {
		this.fileUrls = fileUrls;
	}
	public String[] get_fileIds() {
		return _fileIds;
	}
	public void set_fileIds(String[] _fileIds) {
		this._fileIds = _fileIds;
	}
	public String[] get_fileUrls() {
		return _fileUrls;
	}
	public void set_fileUrls(String[] _fileUrls) {
		this._fileUrls = _fileUrls;
	}
	@Override
	public String toString() {
		return "ttq [fileIds=" + fileIds + ", fileUrls=" + fileUrls + ", _fileIds=" + Arrays.toString(_fileIds)
				+ ", _fileUrls=" + Arrays.toString(_fileUrls) + "]";
	}
    
    
    

}
package testDay01;

import com.alibaba.fastjson.JSON;

public class test01 {
	public static void main(String[] args) {
		String json = "{\"_fileIds\":\"202202d35174f418a5447a8d7c918b6af2156a,2022021f1534d292c34ef5bf5a74519b204525\",\r\n" + 
				"\"_fileUrls\":\"0290bf3bf9174f37a8984915d396fa94.png,Capture001.png\"}";
		System.out.println(json);
		
		ttq t = JSON.parseObject(json, ttq.class);
		System.out.println(t.toString());
		
	}
}

上述代码执行后:

{"_fileIds":"202202d35174f418a5447a8d7c918b6af2156a,2022021f1534d292c34ef5bf5a74519b204525",
"_fileUrls":"0290bf3bf9174f37a8984915d396fa94.png,Capture001.png"}
ttq [fileIds=202202d35174f418a5447a8d7c918b6af2156a,2022021f1534d292c34ef5bf5a74519b204525, fileUrls=0290bf3bf9174f37a8984915d396fa94.png,Capture001.png, _fileIds=null, _fileUrls=null]
 

如果去点对象的fileIds属性时:

 此时执行程序会抛出异常,结果如下:

 如果将fileIds去掉,保留_fileIds,并将类型转为String类型,此时_fileIds可以正常传参。

如果同时拥有fileIds和_fileIds,并且设置都是String,那么此时仍然只有fileIds可以正常赋值。

 运行结果:

{"_fileIds":"202202d35174f418a5447a8d7c918b6af2156a,2022021f1534d292c34ef5bf5a74519b204525",
"_fileUrls":"0290bf3bf9174f37a8984915d396fa94.png,Capture001.png"}
ttq [_fileIds=null, fileIds=202202d35174f418a5447a8d7c918b6af2156a,2022021f1534d292c34ef5bf5a74519b204525, fileUrls=0290bf3bf9174f37a8984915d396fa94.png,Capture001.png, _fileUrls=null]
 

原因:

       通过上面的分析可以得到:com.alibaba.fastjson.JSON.parseObject(仅限fastjson-1.2.56.jar版本,其他版本未测试,结果未知)进行json转对象时只有当后端对象只有带前缀下划线的属性时,前端json带的下划线属性才能正确注入到后端对应的带下划线的对象属性,否则如果后端对象同时存在不带下划线和带下划线的属性,那么前端带下划线属性的json只能注入到后端不带下划线的属性里面。

### 前端使用下划线法传递参数 在前端开发中,遵循良好的编码实践对于提高代码质量和可维护性至关重要。当涉及到参数传递时,尤其是在 JavaScript 和 Vue.js 这样的框架内工作时,推荐使用清晰一致的命约定来定义函数参数或组件属性。 #### 使用下划线法作为参数 下划线法(snake_case),即单词之间通过下划线连接而全部字母均小写的风格,在某些情况下被用于表示变量或方法参数。这种方式有助于区分其他编程习惯如驼峰式大小写,并能增强代码的易读性和一致性[^1]。 下面是一个简单的例子展示如何利用这种命方式向函数内部传送数据: ```javascript function calculate_total_price(item_name, item_quantity, unit_price) { let total = item_quantity * unit_price; console.log(`The total price of ${item_name} is $${total}.`); } // 调用此函数并传入相应参数 calculate_total_price('apple', 5, 0.99); ``` 在这个实例里,`item_name`, `item_quantity`, 和 `unit_price` 都采用了下划线法则,使得每个参数的意义更加直观明了。 另外,在构建基于 Vue 的应用程序时也可以应用相同的原则设置 props 属性: ```html <template> <div class="product"> <!-- 组件模板 --> </div> </template> <script> export default { name: 'ProductComponent', props: { product_id: Number, product_title: String, base_cost: Number } } </script> ``` 这里展示了怎样在一个自定义组件 ProductComponent 中接收来自父级组件的数据流,其中所有的 prop 字都按照 snake_case 形式书写以便更好地传达其含义给开发者们。 #### 注意事项 尽管如此,值得注意的是并非所有环境都偏好下划线法;特别是在 JavaScript 社区中更为普遍的做法是采用 camelCase 或 PascalCase 方式来进行命。因此,在决定具体项目应该采取哪种命规则之前,请务必考虑团队共识以及所处技术栈的最佳实践指南。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值