sgip短信网关开发遇到的问题总结

前早段时间接手一个关于联通短信网关的项目,此项目是同事在网上down的代码上进行二次开发而成!
经过艰难的一个月调试,终于告一段落!给我感触最深的2个想法就是:
1.上传到网上或者分享给别人代码务必多进行测试,尽量保证正确,对于代码来说半成品与废品差不了多少!
行百里者半于九十,有时候真正花费时间仅仅是少数几个问题!
2.不要对别人封装的代码有敬畏之心,改动刀子的地方尽可大胆去尝试!
下面说说项目中具体遇到一些问题吧!(因为是维护,其中关于打包/解包,socket,协议等就不多说了)
一 . 发送方面的问题(sp—>手机)
因发送数据是持久在数据库中,系统启动时启动一线程,循环扫描数据库,查询记录后进行发送!
即:try{
while(true){
//读取数据库
//发送
//更新状态
}catch{
}
}
这结构出现2个问题
1.try在循环外面,一旦出现异常,线程就停止,所以必须将其放入循环里!
2.循环不能用true,而应该用标志位,在函数外可以将其置位来控制线程的运行状态!我们采用在spring装载类时指定init-method="start" destroy-method="dispose">
这样在此线程随类装载而启动,销毁而停止!
二.多线程的问题
现有发送线程sendTread与接收线程recvThread
sendTread
{
A//insert records
}
recvThread
{
B//select  records
}
在以上结构的情况有可能会在发送进程中插入的数据,在接收方如果马上去查可能会读不到,因为数据持久化需要一定时间!
所以可以采用在B尽量让线程sleep一会或者采用循环读取直到读到数据才往下执行!
三.长短信的问题(遗留问题)
其实这个问题我没解决,最后没办法只能在前台将输入短信内容限制在70字!
我根据http://blog.csdn.net/xzdwfwt111/archive/2009/02/19/3908983.aspx这个兄弟说得进行尝试,
这种方式是交给网关去处理,可以不知怎么每次第一条短信前面会有乱码!
另外尝试过自己对短信内容进行拆分,后来发现中英文与字符长度问题,感觉挺复杂,因时间问题而又放弃!
四.其他问题
1.应答消息的包头序列号与原消息的序列号必须是一样的!
2.应答消息打包时候长度不能出错,否则网关收不到正确的消息,会重发原消息三次!
上班时间,只是凭着记忆整理了下!

你可能感兴趣的:(spring,多线程,数据结构,.net,socket)