4.1 infoX接口断连的原因概述
接口断连的原因一般可分为三类,分别为:
A、握手超时(Enquire Link)
B、业务模块发送的消息协议错误
C、TCP/IP的SOCKET关闭或产生异常。
以下将对各情况进行描述。
4.2 业务模块发送的消息协议错误
此情况由于客户模块发送了结构错误的消息,或者消息错位,导致infoX读取消息错误。由于infoX与客户模块采用消息流格式,为防止由于消息错位造成以后的消息都不能正确取得,此时,对于基中的某些消息,infoX将断连接口。原因分别为:
错误码 原因分析 后续操作
97001 缺省解码失败 为防止以后消息错位,接口将断连
97002 消息头错误 为防止以后消息错位,接口将断连
97003 源缓冲区不够,不处理 继续接收消息
97004 目的缓冲区不够 为防止以后消息错位,接口将断连
97005 严重协议错误 为防止以后消息错位,接口将断连
97006 协议中某字段一般性错误 只删除此消息,不断开接口
97007 接收到NACK消息 为防止以后消息错位,接口将断连
97008 接收太多的握手 接口将断连
97009 地址错误,NPI、TON不支持 只删除此消息,不断开接口
97010 时间格式错误 只删除此消息,不断开接口
97011 DCS错误 只删除此消息,不断开接口
97012 协议不支持 只删除此消息,不断开接口
97013~97999 保留
例:
2001/05/28 15:31:03 2 ID为32的接口产生接口断连信息,对端地址:10.10.2.1 ErrCode:97001,ErrorType:0
4.3 握手或接收异常错误
错误码 原因分析 后续操作
19000 保留
19001 接收消息的Buff出了问题 接口将断连
19002 解码返回的值不对(只能是0/-1/>0) 接口将断连
19003 握手超时 接口将断连
19004 对端主动关闭Socket
19005 连接对方服务器的间隔时间,到时重连
19006 发送Login请求后,等待对方服务器的应答消息超时
19007 进行Socket底层的连接建立,等待connect函数的时间
19008 Dsmpfep read消息错误
4.4 TCP/IP的SOCKET关闭或产生异常
此情况是由于客户端主动关闭退出产生的提示信息,错误代码为“0”;
例:
2001/05/28 15:32:14 2 ID为32的接口产生接口断连信息,对端地址:10.10.2.1 ErrCode:0,ErrorType:0
或者由于SOCKET底层的其它异常错误,导致接口断连,此时的错误码将有多种多样,详细描述请见WINDOWS平台SOCKET错误码说明及UNIX平台错误码说明。
例:
2001/05/30 15:49:32 2 ID为32的接口产生接口断连信息,对端地址:10.10.2.1 ErrCode:10054,ErrorType:0
4.5 WINDOWS平台SOCKET错误码说明
MSDN对于SOCKET异常ID的描述
错误码值 错误码标识 含义
10004 WSAEINTR Interrupted function call.
A blocking operation was interrupted by a call to WSACancelBlockingCall.
10013 WSAEACCES Permission denied.
An attempt was made to access a socket in a way forbidden by its access permissions. An example is using a broadcast address for sendto without broadcast permission being set using setsockopt(SO_BROADCAST).
10014 WSAEFAULT Bad address.
The system detected an invalid pointer address in attempting to use a pointer argument of a call. This error occurs if an application passes an invalid pointer value, or if the length of the buffer is too small. For instance, if the length of an argument which is a struct sockaddr is smaller than sizeof(struct sockaddr).
10022 WSAEINVAL Invalid argument.
Some invalid argument was supplied (for example, specifying an invalid level to the setsockopt function). In some instances, it also refers to the current state of the socket - for instance, calling accept on a socket that is not listening.
10024 WSAEMFILE Too many open files.
Too many open sockets. Each implementation may have a maximum number of socket handles available, either globally, per process or per thread.
10035 WSAEWOULDBLOCK Resource temporarily unavailable.
This error is returned from operations on non-blocking sockets that cannot be completed immediately, for example recv when no data is queued to be read from the socket. It is a non-fatal error, and the operation should be retried later. It is normal for WSAEWOULDBLOCK to be reported as the result from calling connect on a non-blocking SOCK_STREAM socket, since some time must elapse for the connection to be established.
10036 WSAEINPROGRESS Operation now in progress.
A blocking operation is currently executing. Windows Sockets only allows a single blocking operation to be outstanding per task (or thread), and if any other function call is made (whether or not it references that or any other socket) the function fails with the WSAEINPROGRESS error.
10037 WSAEALREADY Operation already in progress.
An operation was attempted on a non-blocking socket that already had an operation in progress - i.e. calling connect a second time on a non-blocking socket that is already connecting, or canceling an asynchronous request (WSAAsyncGetXbyY) that has already been canceled or completed.
10038 WSAENOTSOCK Socket operation on non-socket.
An operation was attempted on something that is not a socket. Either the socket handle parameter did not reference a valid socket, or for select, a member of an fd_set was not valid.
10039 WSAEDESTADDRREQ Destination address required.
A required address was omitted from an operation on a socket. For example, this error will be returned if sendto is called with the remote address of ADDR_ANY.
10040 WSAEMSGSIZE Message too long.
A message sent on a datagram socket was larger than the internal message buffer or some other network limit, or the buffer used to receive a datagram into was smaller than the datagram itself.
10041 WSAEPROTOTYPE Protocol wrong type for socket.
A protocol was specified in the socket function call that does not support the semantics of the socket type requested. For example, the ARPA Internet UDP protocol cannot be specified with a socket type of SOCK_STREAM.
10042 WSAENOPROTOOPT Bad protocol option.
An unknown, invalid or unsupported option or level was specified in a getsockopt or setsockopt call.
10043 WSAEPROTONOSUPPORT Protocol not supported.
The requested protocol has not been configured into the system, or no implementation for it exists. For example, a socket call requests a SOCK_DGRAM socket, but specifies a stream protocol.
10044 WSAESOCKTNOSUPPORT Socket type not supported.
The support for the specified socket type does not exist in this address family. For example, the optional type SOCK_RAW might be selected in a socket call, and the implementation does not support SOCK_RAW sockets at all.
10045 WSAEOPNOTSUPP Operation not supported.
The attempted operation is not supported for the type of object referenced. Usually this occurs when a socket descriptor to a socket that cannot support this operation, for example, trying to accept a connection on a datagram socket.
10046 WSAEPFNOSUPPORT Protocol family not supported.
The protocol family has not been configured into the system or no implementation for it exists. Has a slightly different meaning to WSAEAFNOSUPPORT, but is interchangeable in most cases, and all Windows Sockets functions that return one of these specify WSAEAFNOSUPPORT.
10047 WSAEAFNOSUPPORT Address family not supported by protocol family.
An address incompatible with the requested protocol was used. All sockets are created with an associated "address family" (i.e. AF_INET for Internet Protocols) and a generic protocol type (i.e. SOCK_STREAM). This error will be returned if an incorrect protocol is explicitly requested in the socket call, or if an address of the wrong family is used for a socket, e.g. in sendto.
10048 WSAEADDRINUSE Address already in use.
Only one usage of each socket address (protocol/IP address/port) is normally permitted. This error occurs if an application attempts to bind a socket to an IP address/port that has already been used for an existing socket, or a socket that wasn't closed properly, or one that is still in the process of closing. For server applications that need to bind multiple sockets to the same port number, consider using setsockopt(SO_REUSEADDR). Client applications usually need not call bind at all - connect will choose an unused port automatically. When bind is called with a wild-card address (involving ADDR_ANY), a WSAEADDRINUSE error could be delayed until the specific address is "committed." This could happen with a call to other function later, including connect, listen, WSAConnect or WSAJoinLeaf.
10049 WSAEADDRNOTAVAIL Cannot assign requested address.
The requested address is not valid in its context. Normally results from an attempt to bind to an address that is not valid for the local machine. This can also result from connect, sendto, WSAConnect, WSAJoinLeaf, or WSASendTo when the remote address or port is not valid for a remote machine (e.g. address or port 0).
10050 WSAENETDOWN Network is down.
A socket operation encountered a dead network. This could indicate a serious failure of the network system (i.e. the protocol stack that the WinSock DLL runs over), the network interface, or the local network itself.
10051 WSAENETUNREACH Network is unreachable.
A socket operation was attempted to an unreachable network. This usually means the local software knows no route to reach the remote host.
10052 WSAENETRESET Network dropped connection on reset.
The connection has been broken due to "keep-alive" activity detecting a failure while the operation was in progress. It can also be returned by setsockopt if an attempt is made to set SO_KEEPALIVE on a connection that has already failed.
10053 WSAECONNABORTED Software caused connection abort.
An established connection was aborted by the software in your host machine, possibly due to a data transmission timeout or protocol error.
10054 WSAECONNRESET Connection reset by peer.
A existing connection was forcibly closed by the remote host. This normally results if the peer application on the remote host is suddenly stopped, the host is rebooted, or the remote host used a "hard close" (see setsockopt for more information on the SO_LINGER option on the remote socket.) This error may also result if a connection was broken due to "keep-alive" activity detecting a failure while one or more operations are in progress. Operations that were in progress fail with WSAENETRESET. Subsequent operations fail with WSAECONNRESET.
10055 WSAENOBUFS No buffer space available.
An operation on a socket could not be performed because the system lacked sufficient buffer space or because a queue was full.
10056 WSAEISCONN Socket is already connected.
A connect request was made on an already connected socket. Some implementations also return this error if sendto is called on a connected SOCK_DGRAM socket (For SOCK_STREAM sockets, the to parameter in sendto is ignored), although other implementations treat this as a legal occurrence.
10057 WSAENOTCONN Socket is not connected.
A request to send or receive data was disallowed because the socket is not connected and (when sending on a datagram socket using sendto) no address was supplied. Any other type of operation might also return this error - for example, setsockopt setting SO_KEEPALIVE if the connection has been reset.
10058 WSAESHUTDOWN Cannot send after socket shutdown.
A request to send or receive data was disallowed because the socket had already been shut down in that direction with a previous shutdown call. By calling shutdown a partial close of a socket is requested, which is a signal that sending or receiving or both has been discontinued.
10060 WSAETIMEDOUT Connection timed out.
A connection attempt failed because the connected party did not properly respond after a period of time, or established connection failed because connected host has failed to respond.
10061 WSAECONNREFUSED Connection refused.
No connection could be made because the target machine actively refused it. This usually results from trying to connect to a service that is inactive on the foreign host - i.e. one with no server application running.
10064 WSAEHOSTDOWN Host is down.
A socket operation failed because the destination host was down. A socket operation encountered a dead host. Networking activity on the local host has not been initiated. These conditions are more likely to be indicated by the error WSAETIMEDOUT.
10065 WSAEHOSTUNREACH No route to host.
A socket operation was attempted to an unreachable host. See WSAENETUNREACH
10067 WSAEPROCLIM Too many processes.
A Windows Sockets implementation may have a limit on the number of applications that may use it simultaneously. WSAStartup may fail with this error if the limit has been reached.
10091 WSASYSNOTREADY Network subsystem is unavailable.
This error is returned by WSAStartup if the Windows Sockets implementation cannot function at this time because the underlying system it uses to provide network services is currently unavailable. Users should check:
that the appropriate Windows Sockets DLL file is in the current path,
that they are not trying to use more than one Windows Sockets implementation simultaneously. If there is more than one WINSOCK DLL on your system, be sure the first one in the path is appropriate for the network subsystem currently loaded.
the Windows Sockets implementation documentation to be sure all necessary components are currently installed and configured correctly.
10092 WSAVERNOTSUPPORTED WINSOCK.DLL version out of range.
The current Windows Sockets implementation does not support the Windows Sockets specification version requested by the application. Check that no old Windows Sockets DLL files are being accessed.
10093 WSANOTINITIALISED Successful WSAStartup not yet performed.
Either the application hasn't called WSAStartup or WSAStartup failed. The application may be accessing a socket which the current active task does not own (i.e. trying to share a socket between tasks), or WSACleanup has been called too many times.
10094 WSAEDISCON Graceful shutdown in progress.
Returned by WSARecv and WSARecvFrom to indicate the remote party has initiated a graceful shutdown sequence.
10109 WSATYPE_NOT_FOUND Class type not found.
The specified class was not found.
11001 WSAHOST_NOT_FOUND Host not found.
No such host is known. The name is not an official hostname or alias, or it cannot be found in the database(s) being queried. This error may also be returned for protocol and service queries, and means the specified name could not be found in the relevant database.
11002 WSATRY_AGAIN Non-authoritative host not found.
This is usually a temporary error during hostname resolution and means that the local server did not receive a response from an authoritative server. A retry at some time later may be successful.
11003 WSANO_RECOVERY This is a non-recoverable error.
This indicates some sort of non-recoverable error occurred during a database lookup. This may be because the database files (e.g. BSD-compatible HOSTS, SERVICES or PROTOCOLS files) could not be found, or a DNS request was returned by the server with a severe error.
11004 WSANO_DATA Valid name, no data record of requested type.
The requested name is valid and was found in the database, but it does not have the correct associated data being resolved for. The usual example for this is a hostname -> address translation attempt (using gethostbyname or WSAAsyncGetHostByName) which uses the DNS (Domain Name Server), and an MX record is returned but no A record - indicating the host itself exists, but is not directly reachable.
4.6 UNIX平台SOCKET错误码说明
错误码值 错误码标识 含义
HP平台
10001 EPERM Not super-user
10002 ENOENT No such file or directory
10003 ESRCH No such process
10004 EINTR interrupted system call
10005 EIO I/O error
10006 ENXIO No such device or address
10007 E2BIG Arg list too long
10008 ENOEXEC Exec format error
10009 EBADF Bad file number
10010 ECHILD No children
10011 EAGAIN No more processes
10012 ENOMEM Not enough core
10013 EACCES Permission denied
10014 EFAULT Bad address
10015 ENOTBLK Block device required
10016 EBUSY Mount device busy
10017 EEXIST File exists
10018 EXDEV Cross-device link
10019 ENODEV No such device
10020 ENOTDIR Not a directory
10021 EISDIR Is a directory
10022 EINVAL Invalid argument
10023 ENFILE File table overflow
10024 EMFILE Too many open files
10025 ENOTTY Not a typewriter
10026 ETXTBSY Text file busy
10027 EFBIG File too large
10028 ENOSPC No space left on device
10029 ESPIPE Illegal seek
10030 EROFS Read only file system
10031 EMLINK Too many links
10032 EPIPE Broken pipe
10033
10034
10035 ENOMSG No message of desired type
10036 EIDRM Identifier removed
10037 ECHRNG Channel number out of range
10038 EL2NSYNC Level 2 not synchronized
10039 EL3HLT Level 3 halted
10040 EL3RST Level 3 reset
10041 ELNRNG Link number out of range
10042 EUNATCH Protocol driver not attached
10043 ENOCSI No CSI structure available
10044 EL2HLT Level 2 halted
10045 EDEADLK A deadlock would occur
10046 ENOLCK System record lock table was full
10047 EILSEQ Illegal byte sequence
10048
10049
10050 ENONET Machine is not on the network
10051 ENODATA no data (for no delay io)
10052 ETIME timer expired
10053 ENOSR out of streams resources
10054 ENOSTR Device not a stream
10055 ENOPKG Package not installed
10056
10057 ENOLINK the link has been severed
10058 EADV advertise error
10059 ESRMNT srmount error
10060 ECOMM Communication error on send
10061 EPROTO Protocol error
10064 EMULTIHOP multihop attempted
10066 EDOTDOT Cross mount point (not really error)
10067 EBADMSG trying to read unreadable message
10068 EUSERS For Sun compatibilty, will not occur.
10069 EDQUOT Disc quota exceeded
10070 ESTALE Stale NFS file handle
10071 EREMOTE Too many levels of remote in path
10072 EOVERFLOW Value too large to be stored in data type
10152 ENOLOAD Cannot load required kernel module
10153 ERELOC Object file error in loading kernel module
10154 ENOMATCH Symbol matching given spec not found
10155 ENOUNLD Cannot unload kernel module
10156 EBADVER Version number mismatch for loadable kernel module
10157 ECONFIG Configured kernle resource exhausted
10158 ENOREG Cannot register required kernel module
10159 ENOUNREG Cannot unregister kernel module
10215 ENOSYM symbol does not exist in executable
10216 ENOTSOCK Socket operation on non-socket
10217 EDESTADDRREQ Destination address required
10218 EMSGSIZE Message too long
10219 EPROTOTYPE Protocol wrong type for socket
10220 ENOPROTOOPT Protocol not available
10221 EPROTONOSUPPORT Protocol not supported
10222 ESOCKTNOSUPPORT Socket type not supported
10223 EOPNOTSUPP Operation not supported
10224 EPFNOSUPPORT Protocol family not supported
10225 EAFNOSUPPORT Address family not supported by protocol family
10226 EADDRINUSE Address already in use
10227 EADDRNOTAVAIL Can't assign requested address
10228 ENETDOWN Network is down
10229 ENETUNREACH Network is unreachable
10230 ENETRESET Network dropped connection on
10231 ECONNABORTED Software caused connection abort
10232 ECONNRESET Connection reset by peer
10233 ENOBUFS No buffer space available
10234 EISCONN Socket is already connected
10235 ENOTCONN Socket is not connected
10236 ESHUTDOWN Can't send after socket shutdown
10237 ETOOMANYREFS Too many references: can't splice
ECONNREFUSED EREFUSED Double define for NFS
10238 ETIMEDOUT Connection timed out
10239 ECONNREFUSED Connection refused
10240 EREMOTERELEASE Remote peer released connection
10241 EHOSTDOWN Host is down
10242 EHOSTUNREACH No route to host
10244 EALREADY Operation already in progress
10245 EINPROGRESS Operation now in progress
10246 EWOULDBLOCK Operation would block
10247 ENOTEMPTY Directory not empty
10248 ENAMETOOLONG File name too long
10249 ELOOP Too many levels of symbolic links
10251 ENOSYS Function not implemented
10252 ENOTSUP Function not implemented
10253 ECANCELED aio request was canceled before complete
IBM平台
10001 EPERM Operation not permitted
10002 ENOENT No such file or directory
10003 ESRCH No such process
10004 EINTR interrupted system call
10005 EIO I/O error
10006 ENXIO No such device or address
10007 E2BIG Arg list too long
10008 ENOEXEC Exec format error
10009 EBADF Bad file descriptor
10010 ECHILD No child processes
10011 EAGAIN Resource temporarily unavailable
10012 ENOMEM Not enough space
10013 EACCES Permission denied
10014 EFAULT Bad address
10015 ENOTBLK Block device required
10016 EBUSY Resource busy
10017 EEXIST File exists
10018 EXDEV Improper link
10019 ENODEV No such device
10020 ENOTDIR Not a directory
10021 EISDIR Is a directory
10022 EINVAL Invalid argument
10023 ENFILE Too many open files in system
10024 EMFILE Too many open files
10025 ENOTTY Inappropriate I/O control operation
10026 ETXTBSY Text file busy
10027 EFBIG File too large
10028 ENOSPC No space left on device
10029 ESPIPE Invalid seek
10030 EROFS Read only file system
10031 EMLINK Too many links
10032 EPIPE Broken pipe
10033 EDOM Domain error within math function
10034 ERANGE Result too large
10035 ENOMSG No message of desired type
10036 EIDRM Identifier removed
10037 ECHRNG Channel number out of range
10038 EL2NSYNC Level 2 not synchronized
10039 EL3HLT Level 3 halted
10040 EL3RST Level 3 reset
10041 ELNRNG Link number out of range
10042 EUNATCH Protocol driver not attached
10043 ENOCSI No CSI structure available
10044 EL2HLT Level 2 halted
10045 EDEADLK Resource deadlock avoided
10046 ENOTREADY Device not ready
10047 EWRPROTECT Write-protected media
10048 EFORMAT Unformatted media
10049 ENOLCK No locks available
10050 ENOCONNECT no connection
10052 ESTALE no filesystem
10053 EDIST old, currently unused AIX errno
10054 EWOULDBLOCK
10055 EINPROGRESS Operation now in progress
10056 EALREADY Operation already in progress
10057 ENOTSOCK Socket operation on non-socket
10058 EDESTADDRREQ Destination address required
10059 EMSGSIZE Message too long
10060 EPROTOTYPE Protocol wrong type for socket
10061 ENOPROTOOPT Protocol not available
10062 EPROTONOSUPPORT Protocol not supported
10063 ESOCKTNOSUPPORT Socket type not supported
10064 EOPNOTSUPP Operation not supported on socket
10065 EPFNOSUPPORT Protocol family not supported
10066 EAFNOSUPPORT Address family not supported by protocol family
10067 EADDRINUSE Address already in use
10068 EADDRNOTAVAIL Can't assign requested address
10069 ENETDOWN Network is down
10070 ENETUNREACH Network is unreachable
10071 ENETRESET Network dropped connection on reset
10072 ECONNABORTED Software caused connection abort
10073 ECONNRESET Connection reset by peer
10074 ENOBUFS No buffer space available
10075 EISCONN Socket is already connected
10076 ENOTCONN Socket is not connected
10077 ESHUTDOWN Can't send after socket shutdown
10078 ETIMEDOUT Connection timed out
10079 ECONNREFUSED Connection refused
10080 EHOSTDOWN Host is down
10081 EHOSTUNREACH No route to host
10082 ERESTART restart the system call
10083 EPROCLIM Too many processes
10084 EUSERS Too many users
10085 ELOOP Too many levels of symbolic links
10086 ENAMETOOLONG File name too long
10087 Directory not empty
10088 EDQUOT Disc quota exceeded
10089 ECORRUPT Invalid file system control data
10093 EREMOTE Item is not local to host
10109 ENOSYS Function not implemented POSIX
10110 EMEDIA media surface error
10111 ESOFT I/O completed, but needs relocation
10112 ENOATTR no attribute found
10113 ESAD security authentication denied
10114 ENOTRUST not a trusted program
10115 ETOOMANYREFS Too many references: can't splice
10116 EILSEQ Invalid wide character
10117 ECANCELED asynchronous i/o cancelled
10118 ENOSR temp out of streams resources
10119 ETIME I_STR ioctl timed out
10120 EBADMSG wrong message type at stream head
10121 EPROTO STREAMS protocol error
10122 ENODATA no message ready at stream head
10123 ENOSTR fd is not a stream
10124 ENOTSUP POSIX threads unsupported value
10125 EMULTIHOP multihop is not allowed
10126 ENOLINK the link has been severed
10127 EOVERFLOW value too large to be stored in data type
回页首
|
1、如何进行登录失败原因分析
ICP登录网关经常会失败,主要有一下原因,如果ICP使用自己的API可以对登录的应答消息中消息状态字段进行分析,下面列出了主要的错误原因:
SMPP协议 CMPP协议 错误码含义
status=0 result=0 登录成功
status=6 result=2 登录帐号名在系统不存在
status=11 result=3 登录效验密码错误
status=9 result=9 超过最大接口数(帐号限制或总数限制)
status=48 result=48 对端设备IP被限制
如果是使用公司提供的动态库(动态库只提供成功与失败两种状态),则也着重按上述情况进行原因分析。
注:前提为初始化接口成功
2、消息发送失败原因分析
ICP提交消息失败,可通过多种方式对其原因进行分析,首先最常见的方法是使用维测台跟踪消息,看其应答消息的返回状态,下面列出了提交消息常见的错误码,可进行参考分析。
SMPP协议 CMPP协议 错误码含义 备注
status=0 result=0 成功
status=49 result=1 消息结构错 注:这些错误码一般不会在自己的网关出现,只可能此错误是其他网关前转过来。
status=51 result=2 命令字错
status=52 result=3 MsgID错误
status=53 result=4 消息长度错
status=54 result=5 资费代码错误
status=55 result=6 超过的最大信息长度
status=56 result=7 业务代码错误
status=57 result=8 流量控制错
status=59 result=9 前转判断错
status=58 result=10 超过了最大网关前传节点 注:网关常见错误码,这些错误码一般是消息在网关被拒绝掉而产生的。
status= 30 result=11 找不到路由
status=16 result=12 定时发送时间或有效时间错
status= 12 result=13 各种鉴权失败
status=27 result=14 应答超时
status= 19 result=15 接口无效
status=102 result=16 SCP应答超时
其它 result=17~255 短消息中心或SCP处出错
status=60 result=60 黑名单用户 D200版本才支持此特性
常见的SCP出错的错误码(详细内容请参考SCP错误码表)
status=40 result=40 未登记的SP 注:SCP扣费鉴权常见错误码表,详细
status=44 result=44 未登记的SP业务类型
status=50 result=50 移动用户不存在
status=60 result=60 余额不足
常见短消息中心回错误码(公司内部短消息中心)
status=19 result=19 无提交权限 注:短消息中心拒绝掉此消息常见错误。
status=64 result=64 地址错误
status=65 result=65 超过最大提交数
status=66 result=66 超过最大下发数
另外可根据网关产生的Smpp统计话单来进行分析,Smpp话单中的60话单的第16个字段为消息状态,可根据消息状态来进行分析,其列表如下。
0 成功
10 无效的接口ID 注:网关常见错误码,这些错误码一般是消息在网关被拒绝掉而产生的。
12 鉴权失败
16 消息已过有效期
19 发送的接口无效
27 应答超时
30 路由错误,发送不到指定的帐号
40 未登记的SP 注:SCP扣费鉴权常见错误码表。
44 未登记的SP业务类型
50 移动用户不存在
60 余额不足
100 SCP发送错误
102 SCP应答超时
99 消息前转错误 注:其它网关对消息拒绝
19 无提交权限 注:短消息中心拒绝掉此消息常见错误。
64 地址错误
65 超过最大提交数
66 超过最大下发数
一个负数 重发消息错误 启动Msgstore有效
注:此错误码表只作为参考,由于系统连接复杂,各系统的错误码又各成一体,所以会出现错误码冲突的问题。应该具体情况具体分析。
infoX内部使用错误码表:
E_ERROR_MSG
E_SUCCESS 成功
E_ACCESSERR=1 接入码错误
E_CALLERERR=2 主叫错误
E_ACCOUNTERR=3 帐号指针不符
E_SMTYPEERR=4 SmType错误
E_NEWACCOUNTFAIL=5 生成帐号对象失败
E_ACCOUNTNAMEERR=6 帐号名错,查无此帐号
E_CODETYPEERR=7 编码类型错
E_CREATEIFFAIL=8 生成IF对象失败
E_BEYONDMAXIFNUM=9 超过INTERFACEMANAGER的最大IF数
E_INVALIDIFID=10 无效的IF的ID
E_ACCOUNTPASSWORDERR=11 帐号的密码错误
E_NORIGHT=12 没有权限
E_PIDERR=13 PID 错误
E_INVALIDROUTETABLE=14 无效的ROUTETABLE
E_CANNOTFINDIF=15 通过HDRV不能找到IF
E_PARAMERR=16 = 0 参数错
E_STATUSERR=17 状态错误
E_INVALIDACCOUNT =18 无效的ACCOUNT
E_INVALIDIF=19 无效的IF
E_NOSUBMITRIGHT=20 无提交消息权限
E_NODELIVERRIGHT=21 无下发消息权限
E_CHECKTYPEERR=22 鉴权类型错误
E_NUMREPEAT=23 号段重复
E_NOTHISNUM=24 没有指定的号段
E_WATIACK=25 等待应答队列消息错误
E_DCS_ ERROR=26 解码时DCS有错误
E_SUBMIT_TIME_OUT=27 应答超时
E_SUBMIT_ERROR=28 向短消息中心提交消息错误
E_PARSER=29 用户输入消息解析错误
E_SERVICE_NOT_OPEN=30 指定服务未启动
E_IF_STYLE=31 接口类型错误
E_ADDR_FOMRAT=32 地址格式错误
E_PARAM_NO=33 错误的参数类型
E_BIND_SERVICEERR=34 连接时服务类型错误
E_BUFFERERR=35 缓区错误
E_ADD_TRACEERR=36 增加跟踪失败
E_CANCEL_TRACEERR=37 终止跟踪失败
E_ADD_STATERR=38 增加统计任务失败
E_STAT_TYPEERR=39 统计类型错误
E_STAT_NUMERR=40 统计记录错误
E_STAT_IDERR=41 统计ID错误
E_USER_SEND_FAIL=42 user manager send error
E_USER_STATUS=43 用户管理状态转换错误
E_USER_TOMANY=44 用户过多
E_NO_PROMPT=45 无需要应答用户的消息
E_FAILED=46 一般的错误
E_RESOURCE_LIMITED=47 资源不足
E_IP_ERROR=48 连接设备的IP错误
E_SCP_SEND_FAIL = 100 向SCP发送消息时失败
E_SCP_SEND_TIME_OUT = 101 发送消息超时
E_SCP_WAITACK_TIME_OUT = 102 等待SCP的应答超时
E_STATUS_REPORT_TIME_OUT = 103 等待状态报告超时
E_STATUS_REPORT_OVER_FLOW = 104 等待状态报告超时
E_GW_RESEND_ERROR = 160 从备份进程发
E_STORE_TIME_OUT= 0x80000150 在重发进程中超时
E_STORE_BACK_UP = 0x80000151 在重发进程中备份超时
E_STORE_ALREADY_EXIST = 0x80000152 备份时,ID已存在
E_STORE_NOIDLE_ENTITY = 0x80000153 查询时,ID非法
E_STORE_EXPIRE_TIMEOUT = 0x80000154 超过有效期
E_STORE_ENTITY_END = 0x80000155 短消息备份的消息处理结束
E_STORE_ALREADY_WORKING = 0x80000156 消息处在工作态,不能删除
E_STORE_CANCEL= 0x80000157 消息被Cancel
CMPP接口错误码对照表
CMPP_CONNECT_STATUS
E_CMPP_SUCCESS =0 成功
E_CMPP_CONNECT_MSGSTRUCTURE_ERR = 1 消息结构错
E_CMPP_CONNECT_SPID_ERR=2 非法SP_ID
E_CMPP_CONNECT_SPAUTH_ERR=3 SP认证错
E_CMPP_CONNECT_VERSION_ERR=4 版本太高
E_CMPP_CONNECT_OTHER_ERR=5 其他错误
CMPP_SUBMIT_ACK_STATUS
E_CMPP_SUBMIT_MSGSTRUCTURE_ERR = 1 消息结构错
E_CMPP_SUBMIT_COMMANDID_ERR=2 命令字错
E_CMPP_SUBMIT_MSGID_ERR=3 消息序号重复
E_CMPP_SUBMIT_MSG_LEN_ERR=4 消息长度错
E_CMPP_SUBMIT_FEECODE_ERR=5 资费代码错
E_CMPP_SUBMIT_EXCEED_MAX_MSG_LEN=6 超过最大信息长
E_CMPP_SUBMIT_SERVICEID_ERR=7 业务代码错
E_CMPP_SUBMIT_FLOWCONTROL_ERR=8 流量控制错
E_CMPP_SUBMIT_FWD_ESTIMATE_ERR =9 前传判断错
E_CMPP_NODE_NUM=10 超过了最大网关前传节点
E_CMPP_SERVICE_NOT_OPEN=11 找不到路由
E_CMPP_PARAMERR=12 定时发送时间或有效时间错
E_CMPP_NORIGHT=13 各种鉴权失败
E_CMPP_SUBMIT_TIME_OUT=14 应答超时
E_CMPP_INVALIDIF=15 接口无效
E_CMPP_SCP_WAITACK_TIME_OUT=16 SCP应答超时
E_CMPP_SUBMIT_ERR=17~255 其他错误
SCP鉴权扣费错误码表
状态码 含义 备注
-1 状态码错误,未定义的状态码
0 成功
以前使用的错误代码,仍保留,但不使用
1 非神州行预付费用户
2 数据库操作失败
3 鉴权失败 暂不使用
4 超过最大错误次数 暂不使用
5 移动用户帐户数据异常 PPS状态异常
6 服务没有激活
7 用户余额不足
8 超过包月费用上限 暂不使用
9 超过最高欠费额 暂不使用
10 用户已注册该项服务 暂不使用
11 用户没有注册该项服务 暂不使用
12 移动用户已存在
13 网关向SMC提交短消息失败
14 未登记的网关
15 网关登录摘要错误 网关生成摘要与SCP摘要不一致。
16 参数错误
17 服务器端数据未传完 暂不使用
18 重复发送消息序列号msgid相同的单条计费请求消息 新增加(MNET2.1.D5)
系统错误,后面的几类错误代码无法说明的才用系统错误代码
20 未知错误
21 数据库错误
22 SCP互联失败
23 数值越界 折扣>100,费率<0等
24 字段超长 字符串字段长度超长
25 无相关数据 在数据库充查询不到数据
26 数据重复 表中已经存在相同关键字的数据
网关检查
30 未登记的网关
31 网关登录摘要错误
32 网关已存在
33 网关帐户状态异常 网关未激活
34 不支持的摘要算法 目前仅支持MD5
SP检查
40 未登记的SP
41 SP帐户状态异常 SP未激活
42 SP无权限
43 SP帐户已存在
44 未登记的SP业务类型
45 SP业务类型数据异常 SP的业务类型数据未激活
46 SP业务类型已存在
手机用户检查
50 移动用户不存在 不存在此手机号码
51 移动用户状态异常 PPS状态异常
52 梦网用户已存在
53 梦网用户不存在
54 梦网用户状态异常
55 签约信息已存在
56 签约信息不存在
57 签约数据异常 用户与SP的签约信息数据未激活等。
业务逻辑检查
60 余额不足
61 月消费超额
62 单笔消费超额
63 用户拒绝 用户拒绝付费,保留为扩展。
64 短消息编号已存在 网关生成的短消息编号重复
65 对应扣费请求不存在
66 扣费请求已被确认 收到网关重复的状态报告
67 未定义的计费类型
68 未定义的编码方式
只MGW需要错误代码,内部使用,不对外。
200 未定义用户操作代码
201 未定义用户个性参数
回页首
|