现象:
1.无法上网
2.VOLTE 无法连接
3.BIP 测试不能过
原因:APN配置错误
类型 1. APN的值不正确
2.APN的格式不正确
log分析案例一(BIP测试失败):
从log看,ms 找不到ims类型的apn 12-15 17:42:00.262934 1479 1563 D use-Rlog/RLOG-GSM: [dedicate] DataDispatcher handleDefaultBearerActivationRequest 12-15 17:42:00.263012 1479 1563 D use-Rlog/RLOG-GSM: [dedicate] DataDispatcherUtil extractDefaultPdnActInd DefaultPdnActInd[ transactionId= 6, isEmergency= false, rat_type= 0 ] 12-15 17:42:00.263066 1479 1563 D use-Rlog/RLOG-GSM: [dedicate] DataDispatcher ====Start dump [transactions]==== 12-15 17:42:00.263141 1479 1563 D use-Rlog/RLOG-GSM: [dedicate] DataDispatcher dump transactions[transactionId= 6, request= 900008, apn= ims, phoneId= 0] 12-15 17:42:00.263183 1479 1563 D use-Rlog/RLOG-GSM: [dedicate] DataDispatcher ====End dump [transactions]==== 12-15 17:42:00.264019 1479 1563 D use-Rlog/RLOG-GSM: [dedicate] DataDispatcher Sim1 state now is true ,subId is 2 and numeric = '334020' 12-15 17:42:00.264135 1479 1563 D TelephonyManager: getTelephonyProperty prop value= 334020 12-15 17:42:00.264202 1479 1563 D use-Rlog/RLOG-GSM: [dedicate] DataDispatcher query: selection=numeric = '334020' and type like '%ims%' 12-15 17:42:00.272236 1479 1563 D use-Rlog/RLOG-GSM: [dedicate] DataDispatcher no IMS apn Exists!! 12-15 17:42:00.272365 1479 1563 D use-Rlog/RLOG-GSM: [dedicate] DataDispatcher releaseNwRequest pos: 0, requestApnType: ims 12-15 17:42:00.272596 1479 1563 E use-Rlog/RLOG-GSM: [dedicate] DataDispatcher cb already has been released!! 12-15 17:42:00.272680 1479 1563 D use-Rlog/RLOG-GSM: [dedicate] DataDispatcher ====dump [transactions] but empty====
这题是 BIP 要求 DATA建 PDP连接时,DATA没有在 DB 中找到对应类型的APN导致的 bip fail。 请贵司提供以下文件供敝司 check: alps\frameworks\opt\telephony\src\java\com\android\internal\telephony\cat\bip\BipService.java
请贵司预置APN 时将类型"default | supl" 改成"default | supl" ,DATA就能找到DB中的这个APN了,应该就能正常了。
(default | 多了一个空格在这 supl) 12-31 18:00:56.873051 1462 1462 D DCT : [0]createAllApnList: X mAllApnSettings=[[ApnSettingV3] Internet, 1, 334020, internet.itelcel.com, , , , , , 1, default | supl, IP, IP, true, 0, 0, 0, false, 0, 0, 0, 0, , , [ApnSettingV3] Mensajes Multimedia, 2, 334020, mms.itelcel.com, , http://mms.itelcel.com/servlets/mms, 148.233.151.240, 8080, , 1, mms, IP, IP, true, 0, 0, 0, false, 0, 0, 0, 0, , ]
APN:外文名Access Point Name,指一种网络接入技术,是通过手机上网时必须配置的一个参数,它决定了手机通过哪种接入方式来访问网络;
APN的完整说明在3GPP规范TS23.003 Clause 9中进行了详细定义
APN分为两大类:
WAP业务。
WAP以外的服务,比如:连接因特网。
APN概述:
APN 的类型分为web(internet),wap,mms三种类型,用于手机中上网时数据交换的接入点名称配置与显示。APN配置的时候,出现的type的值主要有:default,mms,supl,dun。Default常用于一般的数据业务,主要有internet,wap,web;mms类型用于彩信接收发送的业务;supl用于gprs上网;dun用于wifi等上网类型。配置时注意事项:
在合入完成之后注意检查authtype=” ” 。authtype=“” 这种字串是不允许在apns-conf.xml 文件中出现的,会导致所有项目apn读取失败。Type=””这个也不能为空,需求有时会省略它的配置,apn的Type=””值主要分为default,*,mms, supl等,在不确定的情况下,与需求工程师沟通清楚再合入。注释的错误,在xml文件中,注释的格式为如 ,注意后面的必须是-->,否则会有编译不过的错误。mcc和mnc一般合起来为五位,其中mnc的位数为2,如果出现个位数应该自动补全,如1,补为01。如果需求中存在Authentication:normal。说明没有用户名和密码的话,这个鉴权是不需要的。注意检查wap和web一般不涉及彩信等相关端口的配置,没有mmsport,mmsproxy..注意端口写正确。关于authtype, 需求表中没有注明的情况下置为PAP or CHAP或者空(没有authtype这一项)都可以的。authtype这一项未填写,不管有无用户名,会自动默认为PAP or CHAP。dun类型的apn 就是专门用做tethering的。如果没有dun类型的apn,默认用default的。dun后面加上default,是为了在tethering模式下可以进行下载操作。目前很多需求上明确写明只有dun,则按照需求处理。
检查方法:1验证其语法的正确性,可以直接双击用浏览器自带的编译xml检查其语法格式的正确性,不正确的会在浏览器末尾报错。2验证其读取的正确性:
请将配置文件替换到手机,验证一下配置文件的正确性:方法:adb push apns-conf.xml system/etc然后在apnsetting界面 点击reset to default。 3修改手机预设apn的方法:
预设的文件在手机的 system/etc 目录文件名字叫 apns-conf.xml ,可以使用 rm apns-conf.xml 命令将这个删了然后到apn设置的界面去,恢复下默认设置,这个预设的就没有了,就可以手动设置了。
常见故障:
1、开发故障,APN没有拷贝在手机中 故障描述: APN没有拷贝在手机中,APN设置页面列表为空 故障分析:发现已经有APN文件,但是在版本中却没有发现相应的文件合入,检查 在相应的编译文件中分析是否有APN配置文件的添加语句。 代码修改:在项目分支APN文件所在目录下 app\ZTE_CUSTOM\XXX\android\device\zte\products\XXX.mk中添加语句: PRODUCT_COPY_FILES += device/zte/products/apns-conf.xml:system/etc/apns-conf.xml 就可保证相应的APN文件添加到手机中。 2、自测,APN文件读取失败 故障描述:自测时,push APN配置文件到system/etc/后,执行“重置为默认APN”操作。 APN列表为空,说明APN文件读取失败。 故障分析:APN文件参数配置错误,导致读取失败,可能的原因有 代码修改:检查1、authtype若无需求,则不在配置表中列出该项,即不可以出现authtype = “”(authtype参数项中“”内不可为空);2、Type项也不可为空。常见的Type值有default,mms,supl,*等。在不确定的情况下,和需求工程师沟通后再合入。
3、前方故障,APN参数错误导致彩信无法发送 故障描述:彩信无法发送,但可以成功接收 故障分析:APN文件参数配置错误,注意检查彩信涉及的相关端口配置 mmsport,mmsproxy是否正确 代码修改:与需求工程师核对apn需求,若不确定参数正确与否,可请前方测试人员在局方网络下使用对比机对比,参考其apn配置,进行修改。
4、前方故障,APN参数Authentication前方实测与需求不符 故障描述:前方测试,APN参数中authtype项实际为PAP or CHAP,而需求为Authentication:normal 故障分析:当需求中存在签权项Authentication: normal时,若无用户名和密码参数,该鉴权是不需要的,APN配置中可以没有该项;当配置文件中authype为空时,代码中默认会将其设置为PAP or CHAP。 代码修改:Authentication参数值在需求文件中写为 normal,且无用户名和密码参数,则在APN配置文件中不写该项,代码中会默认设置为PAP or CHAP,不做为故障处理。 5、定制需求,漫游时,仍使用原卡MCC/MNC匹配的APN参数 故障描述:当设备漫游到其它网络时,仍然使用卡中原MNC/MCC对应的APN设置
故障分析:APN列表中的APN参数是根据当前网络提供商的MCC/MNC在APN配置表
中匹配获得的。Operator numeric值中前三位为MCC(国家码),接着的三位为MNC(网
络码)。一般当设备漫游时,opeartor numeric为当前网络提供商的值,而该需求要求使
用原卡的MCC/MNC的APN配置,则需要在读取operator numeric处做相应的修改(参
考7x27GB项目宏ZTE_RLNC)。
代码修改:SIMRecords.java文件中,一般情况下,operator 是由PROPERTY_ICC_OPERATOR_NUMBERIC定义;而此处定义为numeric = SystemProperties.get(“gsm.operator.numeric.home”)。
createAllApnList()中,读取operator值
根据numeric.home进行APN匹配,完成APN装载。
6、前方故障,无法自动激活APN列表中的默认APN选项 故障描述:首次开机后,APN列表正常显示,但无法自动激活默认APN;手动激活后,再次开机则可正常激活。 故障分析:该项目APN需求中,有两组MCC/MNC号相同的APN配置,需要通过spn参数进行区别。通过匹配卡中读出的spn参数和APN配置文件中的spn进行默认APN的选择。而出错项目中,需求spn参数与实际不符,导致无法正常匹配,默认APN无法激活。 代码修改:请前方测试人员提供日志,确认正确的spn参数,修改APN配置文件。 目前代码增加了根据spn值进行APN匹配的功能,类似APN,将从卡中读取的spn保存在PREFERSPN_URI.
createAllApnList()代码中,若mSelectSpn = getPreferredSpn(),若spn不为空,则和operator作为selection,在Telephony.Carriers.CONTENT_URI中定位,选择适当的Apn参数加载到allApns中。 接着在buildWaitingApns()中,将卡中读出的spn参数值和APN配置表中读出的spn参数值进行比较,匹配spn相同的Apn配置作为waitingApn。
7、定制需求,APN子网过滤功能 故障描述:当一张卡有多组APN时,除了用SPN区分外,需求要求通过子网(subnet)来区分,实现APN的子网过滤。 故障分析:从卡中读取子网号码:IMSI = MCC + MNC +子网码 +用户码,将APN配置文件中的SPN参数项用子网码来替代。通过匹配卡中的子网码和APN配置文件的子网码参数,区分不同的APN选项。 代码修改: SIMRecord.java中读取subnet值,并设置接口property名字为”gsm.operator.numeric.subnet”。
从卡上读取了subnet信息了后,在GsmDataConnectionTracker.java中的buildWaitingApn()中,进行subnet匹配,选取APN添加到APN列表中。
8、前方故障,在丢失pdp后无法自动恢复,必须手动关闭再打开数据业务后才能恢复。 故障描述:在P743VV项目中,接到外籍投诉,手机上网状态,当转移到信号较弱的地方,会失去数据链接,如果回到信号较强的地方后,无法自动回复数据链接,必须手动关闭再打开才能恢复。 故障分析:该项目在国内虽然没有复现,但是外籍复现此故障的概率较高,分析日志,发现在丢失后没有自动进行重新连接。 代码修改:分析日志,出现这句话:“onDataSetupComplete: Not all permanent failures, retry”,使执行这句话的操作失效,在if中添加宏控制
修改代码:
Gingerbread/develop/app/frameworks/base/telephony/java/com/android/internal/telephony/gsm 的GsmDataConnectionTracker.java中:
9、数据连接图标显示有误
故障描述:ZTE-C N766维护项目_印度SSTL 测试使用过程中,启用数据业务,待机不显示数据业务图标
解决方法:在使能数据连接时,StatusBarPolicy(Context context) 里面监听器PhoneStateListener.LISTEN_DATA_CONNECTION_STATE会获得这个参数并上传,图标显示。
跟踪了代码,打了LOG,编译了framwork.发现在框架层Phonestatelistener.java里面走到了case LISTEN_DATA_CONNECTION_STATE,这个函数onDataConnectionStateChanged(int state, int networkType)也被调用,LISTEN_DATA_CONNECTION_STATE也被赋值。
---------------------------------------------------------------
---------------------------------------
apn相关问题总结 --------------------------------------
APN概述:
APN 的类型分为web(internet),wap,mms三种类型,用于手机中上网时数据交换的接入点名称配置与显示。 APN配置的时候,出现的type的值主要有:default,mms,supl,dun。Default常用于一般的数据业务,主要有internet,wap,web.mms类型用于彩信接收发送的业务;supl用于gprs上网;dun用于wifi等上网类型。
配置时注意事项:
1、如果是客户给的apn-conf.xml文件需要看看有没有authenticationtype属性,现在将此属性改为authtype,如果没改可能导致apn读取失败apn列表显示为空。在合入完成之后注意检查authtype=” ” 。authtype=“” 这种字串是不允许在apns-conf.xml 文件中出现的,会导致所有项目apn读取失败。
2、Type=””这个也不能为空,需求有时会省略它的配置,apn的Type=””值主要分为default,*,mms, supl等,在不确定的情况下,与需求工程师沟通清楚再合入。
3、mcc和mnc一般合起来为五位,其中mnc的位数为2,如果出现个位数应该自动补全,如1,补为01。
4、如果需求中存在Authentication:normal。说明没有用户名和密码的话,这个鉴权是不需要的。
5、注意检查wap和web一般不涉及彩信等相关端口的配置,没有mmsport,mmsproxy..注意端口写正确。
6、关于authtype, 需求表中没有注明的情况下置为PAP or CHAP或者空(没有authtype这一项)都可以的。 authtype这一项未填写,不管有无用户名,会自动默认为PAP or CHAP。
8、dun类型的apn 就是专门用做tethering的。如果没有dun类型的apn,默认用default的。dun后面加上default,是为了在tethering模式下可以进行下载操作。目前很多需求上明确写明只有dun,则按照需求处理。
检查方法:
1、验证其语法的正确性,可以直接双击用浏览器自带的编译xml检查其语法格式的正确性,不正确的会在浏览器末尾报错。 2、验证其读取的正确性: 请将配置文件替换到手机,验证一下配置文件的正确性: 方法:adb push apns-conf.xml system/etc 然后在apnsetting界面 点击reset to default。 3、修改手机预设apn的方法: 预设的文件在手机的 system/etc 目录 文件名字叫 apns-conf.xml ,可以使用 rm apns-conf.xml 命令将这个删了 然后到apn设置的界面去,恢复下默认设置,这个预设的就没有了,就可以手动设置了。
常见故障:
1、开发故障,APN没有拷贝在手机中
故障描述: APN没有拷贝在手机中,APN设置页面列表为空 故障分析:发现已经有APN文件,但是在版本中却没有发现相应的文件合入,检查 在相应的编译文件中分析是否有APN配置文件的添加语句。 代码修改:在项目分支APN文件所在目录下 device\mediatek\common\Device.mk 中添加语句: PRODUCT_COPY_FILES += device/mediatek/common/apns-conf.xml:system/etc/apns-conf.xml就可保证相应的APN文件添加到手机中。
2、自测,APN文件读取失败
故障描述:自测时,push APN配置文件到system/etc/后,执行“重置为默认APN”操作。 APN列表为空,说明APN文件读取失败。 故障分析:APN文件参数配置错误,导致读取失败,可能的原因有 代码修改:检查1、authtype若无需求,则不在配置表中列出该项,即不可以出现authtype = “”(authtype参数项中“”内不可为空);2、Type项也不可为空。常见的Type值有default,mms,supl,*等。在不确定的情况下,和需求工程师沟通后再合入。
3、前方故障,APN参数错误导致彩信无法发送
故障描述:彩信无法发送,但可以成功接收 故障分析:APN文件参数配置错误,注意检查彩信涉及的相关端口配置mmsport,mmsproxy是否正确 代码修改:与需求工程师核对apn需求,若不确定参数正确与否,可请前方测试人员在局方网络下使用对比机对比,参考其apn配置,进行修改。
4、前方故障,APN参数Authentication前方实测与需求不符
故障描述:前方测试,APN参数中authtype项实际为PAP or CHAP,而需求为Authentication:normal 故障分析:当需求中存在签权项Authentication: normal时,若无用户名和密码参数,该鉴权是不需要的,APN配置中可以没有该项;当配置文件中authype为空时,代码中默认会将其设置为PAP or CHAP。 代码修改:Authentication参数值在需求文件中写为 normal,且无用户名和密码参数,则在APN配置文件中不写该项,代码中会默认设置为PAP or CHAP,不做为故障处理。
--------------------------------------------------------APN类型------------------------------------------------------------------------------------
APN指一种网络接入技术,是通过手机上网时必须配置的一个参数,它决定了手机通过哪种接入方式来访问网络。
APN类型:
1、default 默认网络连接,当激活时所有数据传输都使用该连接,不能与其他网络连接同时使用 适用场合:绝大部分正常上网时可以使用
2、mms 彩信专用连接,此连接与default类似,用于与载体的多媒体信息服务器对话的应用程序,此连接能与default连接同时使用 适用场合:使用彩信服务时,必须有mms类型的接入点,不必选中,应用程序会自动使用此接入点。
3、supl 是Secure User Plane Location“安全用户面定位”的简写,此连接与default类似,用于帮助定位设备与载体的安全用户面定位服务器对话的应用程序,此连接能与default连接同时使用 适用场合:需要自动切换wap与net接入点的、需要把手机当临时AP的
4、dun Dial Up Networking拨号网络的简称,此连接与default连接类似,用于执行一个拨号网络网桥,使载体能知道拨号网络流量的应用程序,此连接能与default连接同时使用 适用场合:需要使用运营商无线热点的,CMCC、ChinaNet等
5、hipri 高优先级网络,与default类似,但路由设置不同。 只有当进程访问移动DNS服务器,并明确要求使用requestRouteToHost(int, int)才会使用此连接