最近完成了一元购的一期开发工作, 其中遇到的一些问题, 总结一下避免下次再犯 DRY! ! !
微信和支付宝开发
一般来说, 微信和支付宝的demo都没有问题, 最常见的问题就是签名错误. 在遇到签名错误时, 首先想到的就是你的app_id, app_key等参数是否正确. 尤其是微信, 当你同时有微信公众账号和微信支付账号时, 很容易产生混乱.
无论是什么支付, 保证回调的方法的幂等性是至关重要的.
虽然微信和支付宝都提供了可以返回”success”使得微信和支付宝不再重复通知的机制, 但是可能网络原因我们未能通知到支付平台, 那他们则会重复调用我们的接口, 所以在保存之前需要对数据进行判断, 是否已经处理. 对已经处理的数据不再处理
swagger api显示问题
使用spring mvc + swagger时, 可能有些参数使用了默认注解, swagger不会对这些参数进行展示, 可以使用@ModelAttribute对参数进行注解.
保证事务中的操作的正确性
我们的业务有的时候需要在一个事务中, 可能典型的做法是
def obj = select * from table;
if(obj?) {
//一些操作
}
但是因为我们使用mysql, 即使设置级别为可重复读, 也无法解决[幻读] ()(http://baike.baidu.com/view/3511548.htm), (此处更正, 可以解决幻读问题, 亲手实践 详见美团博客) 必须在sql的时候做处理, 比如你需要一个减库存的操作
update goods set stock = stock - 5 where id = ? and stock >= 5;
这样就可以保证你的库存不会减为负数
sql优化问题
总结见: 使用mysql的一些基本原则
数据库分页问题
redis缓存分页问题
添加拦截器避免快速重复提交
mysql 的时间戳在大多数情况下并没什么用
mysql 的 timestamp 类型并不能保存毫秒值, 所以需要毫秒值的场景还是转化成bigint保存,
maven的不同环境配置
一般应该配置dev, test, production三种环境, 便于开发测试和线上部署