CN112651012A - 一种信息处理方法及装置 - Google Patents
一种信息处理方法及装置 Download PDFInfo
- Publication number
- CN112651012A CN112651012A CN202011590241.8A CN202011590241A CN112651012A CN 112651012 A CN112651012 A CN 112651012A CN 202011590241 A CN202011590241 A CN 202011590241A CN 112651012 A CN112651012 A CN 112651012A
- Authority
- CN
- China
- Prior art keywords
- permission
- application
- page
- class
- authority
- Prior art date
- Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
- Granted
Links
Images
Classifications
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F21/00—Security arrangements for protecting computers, components thereof, programs or data against unauthorised activity
- G06F21/30—Authentication, i.e. establishing the identity or authorisation of security principals
- G06F21/44—Program or device authentication
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F8/00—Arrangements for software engineering
- G06F8/30—Creation or generation of source code
- G06F8/38—Creation or generation of source code for implementing user interfaces
Landscapes
- Engineering & Computer Science (AREA)
- Theoretical Computer Science (AREA)
- Software Systems (AREA)
- General Engineering & Computer Science (AREA)
- Physics & Mathematics (AREA)
- General Physics & Mathematics (AREA)
- Computer Security & Cryptography (AREA)
- Human Computer Interaction (AREA)
- Computer Hardware Design (AREA)
- Storage Device Security (AREA)
- Stored Programmes (AREA)
Abstract
本申请示出了一种信息处理方法及装置。通过本申请,原生页面可以不启动透明的Activity页面(对用户不可见),也可以不通过透明的Activity页面向电子设备的操作系统申请权限,而通过调用集成在原生页面中的Fragment/Activity框架的权限委托类就可以向电子设备的操作系统申请权限,从而可以节省启动Activity页面的过程,以及,可以节省启动的Activity页面把权限申请结果回传给原生页面的过程,从而可以节省时间,进而可以提高申请权限的效率。另外,由于可以不启动透明的Activity页面,从而可以节省透明的Activity页面占用的系统资源,进而可以节省申请权限的过程需要耗费的系统资源。
Description
技术领域
本申请涉及计算机技术领域,特别是涉及一种信息处理方法及装置。
背景技术
在应用程序运行的过程中,有时候应用程序需要申请权限,在授权后应用程序才能进行进一步操作。
例如,在一个场景中,用户需要在应用程序的一个页面上上传自己的头像,一种方式是页面调用终端的前置摄像头拍摄用户的头像,然后将拍摄的头像显示在页面上,用户看到图像觉得可以上传的时候可以点击上传按钮,应用程序就可以基于页面向服务端上传用户的头像。其中,页面调用终端的前置摄像头拍摄用户的头像之前,需要申请调用前置摄像头的权限,在得到权限之后,页面才能调用终端的前置摄像头拍摄用户的头像。
其中,应用程序的页面在申请权限时,在一种方式中,应用程序的页面可以基于RxPermissions框架新启动一个透明的Activity页面(对用户不可见),然后通过新启动的Activity页面申请权限,新启动的Activity页面可以接收权限申请结果,然后再把权限申请结果回传给应用程序的页面,如此应用程序的页面中就可以得到权限申请结果。
然而,在上述方式中,由于需要新启动Activity页面来完成申请权限以及接收申请结果的工作,启动Activity页面的过程需要耗费时间,以及新启动的Activity页面把权限申请结果回传给应用程序的页面的过程也需要耗费一段时间,从而会降低申请权限的效率。以及新启动Activity页面需要占用系统资源,导致申请权限的过程需要耗费的系统资源较多。
发明内容
为了提高申请权限的效率以及节省申请权限的过程需要耗费的系统资源,本申请示出了一种信息处理方法及装置。
第一方面,本申请示出了一种信息处理方法,应用于电子设备,所述方法包括:
在原生页面需要向所述电子设备的操作系统申请权限的情况下,所述原生页面调用集成在所述原生页面中的Fragment/Activity框架的权限委托类;
所述权限委托类向所述操作系统的授权页面发送用于申请权限的申请请求;
所述授权页面接收所述申请请求,并根据所述申请请求向所述权限委托类发送权限申请结果;
所述权限委托类接收所述授权页面返回的所述权限申请结果;
所述原生页面调用所述权限委托类得到的所述权限申请结果。
在一个可选的实现方式中,所述权限委托类向所述操作系统的授权页面发送用于申请权限的申请请求,包括:
所述权限委托类调用requestPermissions函数向所述操作系统中的包管理器发送用于获取所述授权页面的页面地址的获取请求;
所述包管理器接收所述获取请求,并向所述权限委托类发送所述页面地址;
所述权限委托类调用requestPermissions函数接收所述页面地址,并根据所述页面地址向所述授权页面发送所述申请请求。
在一个可选的实现方式中,所述根据所述申请请求向所述权限委托类发送权限申请结果,包括:
所述授权页面根据所述申请请求调用所述Fragment/Activity框架中的dispatchActivityResult函数,向所述Fragment/Activity框架回传所述权限申请结果;
所述Fragment/Activity框架调用所述Fragment/Activity框架中的onActivityResult函数,向所述权限委托类回传所述权限申请结果。
在一个可选的实现方式中,所述申请请求中携带申请标识码,且所述权限委托类中存储有所述申请请求中携带的申请标识码;所述权限申请结果也携带申请标识码;
所述方法还包括:
所述Fragment/Activity框架调用所述onActivityResult函数,向所述权限委托类回传所述权限申请结果中的申请标识码;
所述权限委托类调用所述onRequestPermissionsResult函数接收所述权限申请结果中的申请标识码;
所述权限委托类判断接收的申请标识码与所述权限委托类中存储的申请标识码是否相同;
在接收的申请标识码与所述权限委托类中存储的申请标识码相同的情况下,所述权限委托类调用所述onRequestPermissionsResult函数向所述Fragment/Activity框架发送用于请求接收所述权限申请结果的接收请求;
所述Fragment/Activity框架调用onActivityResult函数接收所述接收请求,再根据所述接收请求执行所述调用所述Fragment/Activity框架中的onActivityResult函数,向所述权限委托类回传所述权限申请结果的步骤。
在一个可选的实现方式中,所述原生页面调用所述权限委托类得到的所述权限申请结果,包括:
所述原生页面调用PermissionsResultaction函数来获取所述权限委托类得到的所述权限申请结果。
第二方面,本申请示出了一种信息处理装置,应用于电子设备,所述装置包括:
第一调用模块,用于在原生页面需要向所述电子设备的操作系统申请权限的情况下,调用集成在所述原生页面中的Fragment/Activity框架的权限委托类;
第一发送模块,用于向所述操作系统的授权页面发送用于申请权限的申请请求;
第一接收模块,用于接收所述申请请求;
第二发送模块,用于根据所述申请请求向所述权限委托类发送权限申请结果;
第二接收模块,用于接收所述授权页面返回的所述权限申请结果;
第二调用模块,用于调用所述权限委托类得到的所述权限申请结果。
在一个可选的实现方式中,所述第一发送模块包括:
第一发送单元,用于调用requestPermissions函数向所述操作系统中的包管理器发送用于获取所述授权页面的页面地址的获取请求;
第一接收单元,用于接收所述获取请求;
第二发送单元,用于向所述权限委托类发送所述页面地址;
第二接收单元,用于调用requestPermissions函数接收所述页面地址,并根据所述页面地址向所述授权页面发送所述申请请求。
在一个可选的实现方式中,所述第二发送模块包括:
第一回传单元,用于根据所述申请请求调用所述Fragment/Activity框架中的dispatchActivityResult函数,向所述Fragment/Activity框架回传所述权限申请结果;
第二回传单元,用于调用所述Fragment/Activity框架中的onActivityResult函数,向所述权限委托类回传所述权限申请结果。
在一个可选的实现方式中,所述申请请求中携带申请标识码,且所述权限委托类中存储有所述申请请求中携带的申请标识码;所述权限申请结果也携带申请标识码;
所述第二发送模块还包括:
第三回传单元,用于调用所述onActivityResult函数,向所述权限委托类回传所述权限申请结果中的申请标识码;
第三接收单元,用于调用所述onRequestPermissionsResult函数接收所述权限申请结果中的申请标识码;
判断单元,用于判断接收的申请标识码与所述权限委托类中存储的申请标识码是否相同;
第三发送单元,用于在接收的申请标识码与所述权限委托类中存储的申请标识码相同的情况下,调用所述onRequestPermissionsResult函数向所述Fragment/Activity框架发送用于请求接收所述权限申请结果的接收请求;
第四接收单元,用于调用onActivityResult函数接收所述接收请求;
所述第二回传单元还用于根据所述接收请求调用所述Fragment/Activity框架中的onActivityResult函数,向所述权限委托类回传所述权限申请结果。
在一个可选的实现方式中,所述第二调用模块具体用于:调用PermissionsResultaction函数来获取所述权限委托类得到的所述权限申请结果。
第三方面,本申请示出了一种电子设备,所述电子设备包括:
处理器;
用于存储处理器可执行指令的存储器;
其中,所述处理器被配置为执行如第一方面所述的信息处理方法。
第四方面,本申请示出了一种非临时性计算机可读存储介质,当所述存储介质中的指令由电子设备的处理器执行时,使得电子设备能够执行如第一方面所述的信息处理方法。
第五方面,本申请示出了一种计算机程序产品,当所述计算机程序产品中的指令由电子设备的处理器执行时,使得电子设备能够执行如第一方面所述的信息处理方法。
本申请提供的技术方案可以包括以下有益效果:
在本申请中,在原生页面需要向电子设备的操作系统申请权限的情况下,原生页面调用集成在原生页面中的Fragment/Activity框架的权限委托类。权限委托类向操作系统的授权页面发送用于申请权限的申请请求。操作系统的授权页面接收该申请请求,并根据该申请请求向权限委托类发送权限申请结果。权限委托类接收操作系统的授权页面返回的权限申请结果。原生页面调用权限委托类得到的权限申请结果。
通过本申请,原生页面可以不启动透明的Activity页面(对用户不可见),也可以不通过透明的Activity页面向电子设备的操作系统申请权限,而通过调用集成在原生页面中的Fragment/Activity框架的权限委托类就可以向电子设备的操作系统申请权限,从而可以节省启动Activity页面的过程,以及,可以节省启动的Activity页面把权限申请结果回传给原生页面的过程,从而可以节省时间,进而可以提高申请权限的效率。另外,由于可以不启动透明的Activity页面,从而可以节省透明的Activity页面占用的系统资源,进而可以节省申请权限的过程需要耗费的系统资源。
另外,在编写原生页面的计算机程序代码的过程中,如果是“基于RxPermissions框架新启动一个透明的Activity页面(对用户不可见),然后通过Activity页面调用requestPermissions函数来申请权限,新启动的Activity页面通过onRequestPermissionsResult函数接收权限申请结果,然后再把权限申请结果回传给应用程序的页面”,则由于操作系统对RxPermissions框架中的requestPermissions函数以及onRequestPermissionsResult函数的使用用法的限制,在原生页面的计算机程序代码中,申请权限的计算机程序代码与接收权限申请结果的计算机程序代码往往无法写在相邻的代码行上,例如,申请权限的计算机程序代码在第N行,接收权限申请结果的计算机程序代码可能需要在第N+X行等,例如,X可以大于10或者20等。
而第N行与第N+X行之间是原生页面中的业务代码,这些业务代码需要在申请到权限之后才能使用,这就需要技术人员在编写计算机程序代码时,代码的业务逻辑需要是第N行→第N+X行→第N+1行,代码的业务逻辑与代码的行的顺序不相同,导致代码的可读性差,后续优化代码的复杂度高。
而通过本申请,requestPermissions函数以及RequestPermissionsResult函数的逻辑代码封装在原生页面的计算机程序代码以外的地方(权限委托类),原生页面中的计算机程序代码可以直接调用权限委托类及可实现向电子设备的操作系统申请权限。
如此,在原生页面的计算机程序代码中,调用权限委托类来申请权限的计算机程序代码与回调权限委托类得到的权限申请结果的计算机程序代码可以写在相邻的代码行上,例如,调用权限委托类来申请权限的计算机程序代码在第N行,回调权限委托类得到的权限申请结果的计算机程序代码可以写在第N+1行,在第N+2行以后编写原生页面中的业务代码,使得代码的业务逻辑与代码的行的顺序可以相同,优化了代码的可读性,降低了后续优化代码的复杂度。
附图说明
图1是本申请的一种信息处理方法的步骤流程图;
图2是本申请的一种信息处理装置的结构框图;
图3是本申请示出的一种电子设备的框图;
图4是本申请示出的一种电子设备的框图。
具体实施方式
为使本申请的上述目的、特征和优点能够更加明显易懂,下面结合附图和具体实施方式对本申请作进一步详细的说明。
参照图1,示出了本申请的一种信息处理方法的步骤流程图,该方法应用于电子设备,电子设备中安装有应用程序,应用程序的页面包括基于Fragment/Activity框架开发的页面,Fragment/Activity框架集成有权限委托类(例如PermissionCompatDelegate等),权限委托类用于供应用程序的原生页面向电子设备的操作系统申请权限,例如,原生页面申请使用电子设备的摄像头的权限,原生页面申请使用电子设备的麦克风的权限,原生页面申请访问电子设备的操作系统中记录的用户的通讯录的权限,以及,原生页面申请访问电子设备的操作系统中存储的用户的相册的权限等。
其中,在原生页面需要向电子设备的操作系统申请权限的情况下,可以按照如下方法来实现,参见图1,该方法具体可以包括如下步骤:
在步骤S101中,在原生页面需要向电子设备的操作系统申请权限的情况下,原生页面调用集成在原生页面中的Fragment/Activity框架的权限委托类。
在本申请中,由于原生页面是基于Fragment/Activity框架开发的,且Fragment/Activity框架中集成有权限委托类,因此,原生页面可以直接调用Fragment/Activity框架的权限委托类,以借助权限委托类来向电子设备的操作系统申请权限。
在步骤S102中,权限委托类向操作系统的授权页面发送用于申请权限的申请请求。
在本申请中,在原生页面调用权限委托类之后,可以实现向权限委托类指示需要向电子设备的操作系统申请权限。
如此,为了能够向电子设备的操作系统申请权限,权限委托类可以向操作系统的授权页面发送用于申请权限的申请请求。
其中,权限委托类中至少包括requestPermissions函数以及onRequestPermissionsResult函数等,requestPermissions函数用于向电子设备的操作系统申请权限,onRequestPermissionsResult函数用于接收电子设备的操作系统返回的权限申请结果。
在本步骤中,权限委托类可以调用权限委托类中的requestPermissions函数向电子设备的操作系统中的包管理器发送用于获取操作系统的授权页面的页面地址的获取请求,以获取操作系统的授权页面的页面地址。
其中,包管理器可以接收该获取请求,然后获取操作系统的授权页面的页面地址,例如,包管理器可以获取权限控制应用的包名,然后根据权限控制应用的包名获取操作系统的授权页面的页面地址,具体如何根据权限控制应用的包名获取操作系统的授权页面的页面地址,可以参见已存在的技术方式,在此不做详述,然后可以向权限委托类发送操作系统的页面地址。权限委托类调用requestPermissions函数接收操作系统的授权页面的页面地址,并根据授权页面的页面地址向操作系统的授权页面发送该申请请求。例如,根据授权页面的页面地址调用requestPermissions函数向操作系统的授权页面发送该申请请求。在一个例子中,requestPermissions函数可以调用start activity for result函数向操作系统的授权页面发送该申请请求。
在步骤S103中,操作系统的授权页面接收该申请请求。
在步骤S104中,操作系统的授权页面根据该申请请求向权限委托类发送权限申请结果。
在本申请中,该申请请求中可以携带一些业务参数,例如,原生页面的页面标识、在原生页面上登录的用户的用户名、原生页面中请求权限的业务的业务名以及业务种类等,本申请对具体的业务参数不做限定,操作系统的授权页面可以根据该申请请求中携带的业务参数来确定是否需要为原生页面授予权限,并生成权限申请结果,权限申请结果包括“授予权限”以及“拒绝授予权限”等。
在本申请中,在操作系统的授权页面根据该申请请求向权限委托类发送权限申请结果时,操作系统的授权页面可以根据该申请请求调用Fragment/Activity框架中的dispatchActivityResult函数向Fragment/Activity框架回传权限申请结果,以使得Fragment/Activity框架可以得到权限申请结果。然后Fragment/Activity框架可以调用Fragment/Activity框架中的onActivityResult函数向权限委托类回传权限申请结果,以使权限委托类得到权限申请结果。
在步骤S105中,权限委托类接收操作系统的授权页面返回的权限申请结果。
在本申请中,权限委托类可以调用权限委托类中的onRequestPermissionsResult函数接收onActivityResult函数回传的权限申请结果。
在步骤S106中,原生页面调用权限委托类得到的权限申请结果。
在本申请一个实施例中,原生页面可以调用PermissionsResultAction函数以获取权限委托类得到的权限申请结果。
其中,在实际应用中,原生页面除了可以向电子设备的操作系统申请权限以外,还可以向电子设备的操作系统申请非权限以外的其他数据等,无论向电子设备的操作系统申请什么样的内容,最终的权限申请结果可以经由Fragment/Activity框架的onActivityResult函数来回传。
然而,权限委托类是用于供应用程序的原生页面向电子设备的操作系统申请权限的,原生页面向电子设备的操作系统申请权限的权限申请结果是需要回传给权限委托类的,原生页面向电子设备的操作系统申请非权限以外的其他数据的权限申请结果是不需要回传给权限委托类的。
因此,为了使得Fragment/Activity框架的onActivityResult函数可以确定出申请结果是否需要回传给权限委托类,在本申请另一实施例中,用于申请权限的该申请请求中可以携带申请标识码(其中,向电子设备的操作系统申请不同种类的内容的申请标识码不同,申请权限的申请标识码是特定的且唯一的),以及,权限委托类中存储有该申请请求中携带的申请标识码。权限申请结果也携带申请标识码,例如,操作系统的授权页面也可以在权限申请结果中添加该申请请求中携带的申请标识码等。
如此,在步骤S104中,在Fragment/Activity框架调用Fragment/Activity框架中的onActivityResult函数向权限委托类回传权限申请结果之前,Fragment/Activity框架可以调用onActivityResult函数,向权限委托类回传权限申请结果中的申请标识码。
权限委托类可以调用onRequestPermissionsResult函数接收权限申请结果中的申请标识码。然后权限委托类可以判断接收的申请标识码与权限委托类中存储的申请标识码(即该申请请求中携带的申请标识码)是否相同。
在接收的申请标识码与权限委托类中存储的申请标识码相同的情况下,说明权限申请结果是权限委托类需要接收的,如此,权限委托类可以调用onRequestPermissionsResult函数向Fragment/Activity框架发送用于请求接收权限申请结果的接收请求。
Fragment/Activity框架调用onActivityResult函数接收该接收请求,再根据该接收请求调用Fragment/Activity框架中的onActivityResult函数向权限委托类回传权限申请结果。
在本申请中,在原生页面需要向电子设备的操作系统申请权限的情况下,原生页面调用集成在原生页面中的Fragment/Activity框架的权限委托类。权限委托类向操作系统的授权页面发送用于申请权限的申请请求。操作系统的授权页面接收该申请请求,并根据该申请请求向权限委托类发送权限申请结果。权限委托类接收操作系统的授权页面返回的权限申请结果。原生页面调用权限委托类得到的权限申请结果。
通过本申请,原生页面可以不启动透明的Activity页面(对用户不可见),也可以不通过透明的Activity页面向电子设备的操作系统申请权限,而通过调用集成在原生页面中的Fragment/Activity框架的权限委托类就可以向电子设备的操作系统申请权限,从而可以节省启动Activity页面的过程,以及,可以节省启动的Activity页面把权限申请结果回传给原生页面的过程,从而可以节省时间,进而可以提高申请权限的效率。另外,由于可以不启动透明的Activity页面,从而可以节省透明的Activity页面占用的系统资源,进而可以节省申请权限的过程需要耗费的系统资源。
另外,在编写原生页面的计算机程序代码的过程中,如果是“基于RxPermissions框架新启动一个透明的Activity页面(对用户不可见),然后通过Activity页面调用requestPermissions函数来申请权限,新启动的Activity页面通过onRequestPermissionsResult函数接收权限申请结果,然后再把权限申请结果回传给应用程序的页面”,则由于操作系统对RxPermissions框架中的requestPermissions函数以及onRequestPermissionsResult函数的使用用法的限制,在原生页面的计算机程序代码中,申请权限的计算机程序代码与接收权限申请结果的计算机程序代码往往无法写在相邻的代码行上,例如,申请权限的计算机程序代码在第N行,接收权限申请结果的计算机程序代码可能需要在第N+X行等,例如,X可以大于10或者20等。
而第N行与第N+X行之间是原生页面中的业务代码,这些业务代码需要在申请到权限之后才能使用,这就需要技术人员在编写计算机程序代码时,代码的业务逻辑需要是第N行→第N+X行→第N+1行,代码的业务逻辑与代码的行的顺序不相同,导致代码的可读性差,后续优化代码的复杂度高。
而通过本申请,requestPermissions函数以及RequestPermissionsResult函数的逻辑代码封装在原生页面的计算机程序代码以外的地方(权限委托类),原生页面中的计算机程序代码可以直接调用权限委托类及可实现向电子设备的操作系统申请权限。
如此,在原生页面的计算机程序代码中,调用权限委托类来申请权限的计算机程序代码与回调权限委托类得到的权限申请结果的计算机程序代码可以写在相邻的代码行上,例如,调用权限委托类来申请权限的计算机程序代码在第N行,回调权限委托类得到的权限申请结果的计算机程序代码可以写在第N+1行,在第N+2行以后编写原生页面中的业务代码,使得代码的业务逻辑与代码的行的顺序可以相同,优化了代码的可读性,降低了后续优化代码的复杂度。
需要说明的是,对于方法实施例,为了简单描述,故将其都表述为一系列的动作组合,但是本领域技术人员应该知悉,本申请并不受所描述的动作顺序的限制,因为依据本申请,某些步骤可以采用其他顺序或者同时进行。其次,本领域技术人员也应该知悉,说明书中所描述的实施例均属于可选实施例,所涉及的动作并不一定是本申请所必须的。
参照图2,示出了本申请的一种信息处理装置的结构框图,应用于电子设备,该装置具体可以包括如下模块:
第一调用模块11,用于在原生页面需要向所述电子设备的操作系统申请权限的情况下,调用集成在所述原生页面中的Fragment/Activity框架的权限委托类;
第一发送模块12,用于向所述操作系统的授权页面发送用于申请权限的申请请求;
第一接收模块13,用于接收所述申请请求;
第二发送模块14,用于根据所述申请请求向所述权限委托类发送权限申请结果;
第二接收模块15,用于接收所述授权页面返回的所述权限申请结果;
第二调用模块16,用于调用所述权限委托类得到的所述权限申请结果。
在一个可选的实现方式中,所述第一发送模块包括:
第一发送单元,用于调用requestPermissions函数向所述操作系统中的包管理器发送用于获取所述授权页面的页面地址的获取请求;
第一接收单元,用于接收所述获取请求;
第二发送单元,用于向所述权限委托类发送所述页面地址;
第二接收单元,用于调用requestPermissions函数接收所述页面地址,并根据所述页面地址向所述授权页面发送所述申请请求。
在一个可选的实现方式中,所述第二发送模块包括:
第一回传单元,用于根据所述申请请求调用所述Fragment/Activity框架中的dispatchActivityResult函数,向所述Fragment/Activity框架回传所述权限申请结果;
第二回传单元,用于调用所述Fragment/Activity框架中的onActivityResult函数,向所述权限委托类回传所述权限申请结果。
在一个可选的实现方式中,所述申请请求中携带申请标识码,且所述权限委托类中存储有所述申请请求中携带的申请标识码;所述权限申请结果也携带申请标识码;
所述第二发送模块还包括:
第三回传单元,用于调用所述onActivityResult函数,向所述权限委托类回传所述权限申请结果中的申请标识码;
第三接收单元,用于调用所述onRequestPermissionsResult函数接收所述权限申请结果中的申请标识码;
判断单元,用于判断接收的申请标识码与所述权限委托类中存储的申请标识码是否相同;
第三发送单元,用于在接收的申请标识码与所述权限委托类中存储的申请标识码相同的情况下,调用所述onRequestPermissionsResult函数向所述Fragment/Activity框架发送用于请求接收所述权限申请结果的接收请求;
第四接收单元,用于调用onActivityResult函数接收所述接收请求;
所述第二回传单元还用于根据所述接收请求调用所述Fragment/Activity框架中的onActivityResult函数,向所述权限委托类回传所述权限申请结果。
在一个可选的实现方式中,所述第二调用模块具体用于:调用PermissionsResultaction函数来获取所述权限委托类得到的所述权限申请结果。
在本申请中,在原生页面需要向电子设备的操作系统申请权限的情况下,原生页面调用集成在原生页面中的Fragment/Activity框架的权限委托类。权限委托类向操作系统的授权页面发送用于申请权限的申请请求。操作系统的授权页面接收该申请请求,并根据该申请请求向权限委托类发送权限申请结果。权限委托类接收操作系统的授权页面返回的权限申请结果。原生页面调用权限委托类得到的权限申请结果。
通过本申请,原生页面可以不启动透明的Activity页面(对用户不可见),也可以不通过透明的Activity页面向电子设备的操作系统申请权限,而通过调用集成在原生页面中的Fragment/Activity框架的权限委托类就可以向电子设备的操作系统申请权限,从而可以节省启动Activity页面的过程,以及,可以节省启动的Activity页面把权限申请结果回传给原生页面的过程,从而可以节省时间,进而可以提高申请权限的效率。另外,由于可以不启动透明的Activity页面,从而可以节省透明的Activity页面占用的系统资源,进而可以节省申请权限的过程需要耗费的系统资源。
另外,在编写原生页面的计算机程序代码的过程中,如果是“基于RxPermissions框架新启动一个透明的Activity页面(对用户不可见),然后通过Activity页面调用requestPermissions函数来申请权限,新启动的Activity页面通过onRequestPermissionsResult函数接收权限申请结果,然后再把权限申请结果回传给应用程序的页面”,则由于操作系统对RxPermissions框架中的requestPermissions函数以及onRequestPermissionsResult函数的使用用法的限制,在原生页面的计算机程序代码中,申请权限的计算机程序代码与接收权限申请结果的计算机程序代码往往无法写在相邻的代码行上,例如,申请权限的计算机程序代码在第N行,接收权限申请结果的计算机程序代码可能需要在第N+X行等,例如,X可以大于10或者20等。
而第N行与第N+X行之间是原生页面中的业务代码,这些业务代码需要在申请到权限之后才能使用,这就需要技术人员在编写计算机程序代码时,代码的业务逻辑需要是第N行→第N+X行→第N+1行,代码的业务逻辑与代码的行的顺序不相同,导致代码的可读性差,后续优化代码的复杂度高。
而通过本申请,requestPermissions函数以及RequestPermissionsResult函数的逻辑代码封装在原生页面的计算机程序代码以外的地方(权限委托类),原生页面中的计算机程序代码可以直接调用权限委托类及可实现向电子设备的操作系统申请权限。
如此,在原生页面的计算机程序代码中,调用权限委托类来申请权限的计算机程序代码与回调权限委托类得到的权限申请结果的计算机程序代码可以写在相邻的代码行上,例如,调用权限委托类来申请权限的计算机程序代码在第N行,回调权限委托类得到的权限申请结果的计算机程序代码可以写在第N+1行,在第N+2行以后编写原生页面中的业务代码,使得代码的业务逻辑与代码的行的顺序可以相同,优化了代码的可读性,降低了后续优化代码的复杂度。
对于装置实施例而言,由于其与方法实施例基本相似,所以描述的比较简单,相关之处参见方法实施例的部分说明即可。
图3是本申请示出的一种电子设备800的框图。例如,电子设备800可以是移动电话,计算机,数字广播终端,消息收发设备,游戏控制台,平板设备,医疗设备,健身设备,个人数字助理等。
参照图3,电子设备800可以包括以下一个或多个组件:处理组件802,存储器804,电力组件806,多媒体组件808,音频组件810,输入/输出(I/O)的接口812,传感器组件814,以及通信组件816。
处理组件802通常控制电子设备800的整体操作,诸如与显示,电话呼叫,数据通信,相机操作和记录操作相关联的操作。处理组件802可以包括一个或多个处理器820来执行指令,以完成上述方法的全部或部分步骤。此外,处理组件802可以包括一个或多个模块,便于处理组件802和其他组件之间的交互。例如,处理组件802可以包括多媒体模块,以方便多媒体组件808和处理组件802之间的交互。
存储器804被配置为存储各种类型的数据以支持在设备800的操作。这些数据的示例包括用于在电子设备800上操作的任何应用程序或方法的指令,联系人数据,电话簿数据,消息,图像,视频等。存储器804可以由任何类型的易失性或非易失性存储设备或者它们的组合实现,如静态随机存取存储器(SRAM),电可擦除可编程只读存储器(EEPROM),可擦除可编程只读存储器(EPROM),可编程只读存储器(PROM),只读存储器(ROM),磁存储器,快闪存储器,磁盘或光盘。
电源组件806为电子设备800的各种组件提供电力。电源组件806可以包括电源管理系统,一个或多个电源,及其他与为电子设备800生成、管理和分配电力相关联的组件。
多媒体组件808包括在所述电子设备800和用户之间的提供一个输出接口的屏幕。在一些实施例中,屏幕可以包括液晶显示器(LCD)和触摸面板(TP)。如果屏幕包括触摸面板,屏幕可以被实现为触摸屏,以接收来自用户的输入信号。触摸面板包括一个或多个触摸传感器以感测触摸、滑动和触摸面板上的手势。所述触摸传感器可以不仅感测触摸或滑动动作的边界,而且还检测与所述触摸或滑动操作相关的持续时间和压力。在一些实施例中,多媒体组件808包括一个前置摄像头和/或后置摄像头。当设备800处于操作模式,如拍摄模式或视频模式时,前置摄像头和/或后置摄像头可以接收外部的多媒体数据。每个前置摄像头和后置摄像头可以是一个固定的光学透镜系统或具有焦距和光学变焦能力。
音频组件810被配置为输出和/或输入音频信号。例如,音频组件810包括一个麦克风(MIC),当电子设备800处于操作模式,如呼叫模式、记录模式和语音识别模式时,麦克风被配置为接收外部音频信号。所接收的音频信号可以被进一步存储在存储器804或经由通信组件816发送。在一些实施例中,音频组件810还包括一个扬声器,用于输出音频信号。
I/O接口812为处理组件802和外围接口模块之间提供接口,上述外围接口模块可以是键盘,点击轮,按钮等。这些按钮可包括但不限于:主页按钮、音量按钮、启动按钮和锁定按钮。
传感器组件814包括一个或多个传感器,用于为电子设备800提供各个方面的状态评估。例如,传感器组件814可以检测到设备800的打开/关闭状态,组件的相对定位,例如所述组件为电子设备800的显示器和小键盘,传感器组件814还可以检测电子设备800或电子设备800一个组件的位置改变,用户与电子设备800接触的存在或不存在,电子设备800方位或加速/减速和电子设备800的温度变化。传感器组件814可以包括接近传感器,被配置用来在没有任何的物理接触时检测附近物体的存在。传感器组件814还可以包括光传感器,如CMOS或CCD图像传感器,用于在成像应用中使用。在一些实施例中,该传感器组件814还可以包括加速度传感器,陀螺仪传感器,磁传感器,压力传感器或温度传感器。
通信组件816被配置为便于电子设备800和其他设备之间有线或无线方式的通信。电子设备800可以接入基于通信标准的无线网络,如WiFi,运营商网络(如2G、3G、4G或5G),或它们的组合。在一个示例性实施例中,通信组件816经由广播信道接收来自外部广播管理系统的广播信号或广播操作信息。在一个示例性实施例中,所述通信组件816还包括近场通信(NFC)模块,以促进短程通信。例如,在NFC模块可基于射频识别(RFID)技术,红外数据协会(IrDA)技术,超宽带(UWB)技术,蓝牙(BT)技术和其他技术来实现。
在示例性实施例中,电子设备800可以被一个或多个应用专用集成电路(ASIC)、数字信号处理器(DSP)、数字信号处理设备(DSPD)、可编程逻辑器件(PLD)、现场可编程门阵列(FPGA)、控制器、微控制器、微处理器或其他电子元件实现,用于执行上述方法。
在示例性实施例中,还提供了一种包括指令的非临时性计算机可读存储介质,例如包括指令的存储器804,上述指令可由电子设备800的处理器820执行以完成上述方法。例如,所述非临时性计算机可读存储介质可以是ROM、随机存取存储器(RAM)、CD-ROM、磁带、软盘和光数据存储设备等。
图4是本申请示出的一种电子设备1900的框图。例如,电子设备1900可以被提供为一服务器。
参照图4,电子设备1900包括处理组件1922,其进一步包括一个或多个处理器,以及由存储器1932所代表的存储器资源,用于存储可由处理组件1922的执行的指令,例如应用程序。存储器1932中存储的应用程序可以包括一个或一个以上的每一个对应于一组指令的模块。此外,处理组件1922被配置为执行指令,以执行上述方法。
电子设备1900还可以包括一个电源组件1926被配置为执行电子设备1900的电源管理,一个有线或无线网络接口1950被配置为将电子设备1900连接到网络,和一个输入输出(I/O)接口1958。电子设备1900可以操作基于存储在存储器1932的操作系统,例如Windows ServerTM,Mac OS XTM,UnixTM,LinuxTM,FreeBSDTM或类似。
本说明书中的各个实施例均采用递进的方式描述,每个实施例重点说明的都是与其他实施例的不同之处,各个实施例之间相同相似的部分互相参见即可。
本领域内的技术人员应明白,本申请的实施例可提供为方法、装置、或计算机程序产品。因此,本申请可采用完全硬件实施例、完全软件实施例、或结合软件和硬件方面的实施例的形式。而且,本申请可采用在一个或多个其中包含有计算机可用程序代码的计算机可用存储介质(包括但不限于磁盘存储器、CD-ROM、光学存储器等)上实施的计算机程序产品的形式。
本申请是参照根据本申请的方法、终端设备(系统)、和计算机程序产品的流程图和/或方框图来描述的。应理解可由计算机程序指令实现流程图和/或方框图中的每一流程和/或方框、以及流程图和/或方框图中的流程和/或方框的结合。可提供这些计算机程序指令到通用计算机、专用计算机、嵌入式处理机或其他可编程数据处理终端设备的处理器以产生一个机器,使得通过计算机或其他可编程数据处理终端设备的处理器执行的指令产生用于实现在流程图一个流程或多个流程和/或方框图一个方框或多个方框中指定的功能的装置。
这些计算机程序指令也可存储在能引导计算机或其他可编程数据处理终端设备以特定方式工作的计算机可读存储器中,使得存储在该计算机可读存储器中的指令产生包括指令装置的制造品,该指令装置实现在流程图一个流程或多个流程和/或方框图一个方框或多个方框中指定的功能。
这些计算机程序指令也可装载到计算机或其他可编程数据处理终端设备上,使得在计算机或其他可编程终端设备上执行一系列操作步骤以产生计算机实现的处理,从而在计算机或其他可编程终端设备上执行的指令提供用于实现在流程图一个流程或多个流程和/或方框图一个方框或多个方框中指定的功能的步骤。
尽管已描述了本申请的优选实施例,但本领域内的技术人员一旦得知了基本创造性概念,则可对这些实施例做出另外的变更和修改。所以,所附权利要求意欲解释为包括优选实施例以及落入本申请范围的所有变更和修改。
最后,还需要说明的是,在本文中,诸如第一和第二等之类的关系术语仅仅用来将一个实体或者操作与另一个实体或操作区分开来,而不一定要求或者暗示这些实体或操作之间存在任何这种实际的关系或者顺序。而且,术语“包括”、“包含”或者其任何其他变体意在涵盖非排他性的包含,从而使得包括一系列要素的过程、方法、物品或者终端设备不仅包括那些要素,而且还包括没有明确列出的其他要素,或者是还包括为这种过程、方法、物品或者终端设备所固有的要素。在没有更多限制的情况下,由语句“包括一个……”限定的要素,并不排除在包括所述要素的过程、方法、物品或者终端设备中还存在另外的相同要素。
以上对本申请所提供的一种信息处理方法及装置,进行了详细介绍,本文中应用了具体个例对本申请的原理及实施方式进行了阐述,以上实施例的说明只是用于帮助理解本申请的方法及其核心思想;同时,对于本领域的一般技术人员,依据本申请的思想,在具体实施方式及应用范围上均会有改变之处,综上所述,本说明书内容不应理解为对本申请的限制。
Claims (12)
1.一种信息处理方法,其特征在于,应用于电子设备,所述方法包括:
在原生页面需要向所述电子设备的操作系统申请权限的情况下,所述原生页面调用集成在所述原生页面中的Fragment/Activity框架的权限委托类;
所述权限委托类向所述操作系统的授权页面发送用于申请权限的申请请求;
所述授权页面接收所述申请请求,并根据所述申请请求向所述权限委托类发送权限申请结果;
所述权限委托类接收所述授权页面返回的所述权限申请结果;
所述原生页面调用所述权限委托类得到的所述权限申请结果。
2.根据权利要求1所述的方法,其特征在于,所述权限委托类向所述操作系统的授权页面发送用于申请权限的申请请求,包括:
所述权限委托类调用requestPermissions函数向所述操作系统中的包管理器发送用于获取所述授权页面的页面地址的获取请求;
所述包管理器接收所述获取请求,并向所述权限委托类发送所述页面地址;
所述权限委托类调用requestPermissions函数接收所述页面地址,并根据所述页面地址向所述授权页面发送所述申请请求。
3.根据权利要求1所述的方法,其特征在于,所述根据所述申请请求向所述权限委托类发送权限申请结果,包括:
所述授权页面根据所述申请请求调用所述Fragment/Activity框架中的dispatchActivityResult函数,向所述Fragment/Activity框架回传所述权限申请结果;
所述Fragment/Activity框架调用所述Fragment/Activity框架中的onActivityResult函数,向所述权限委托类回传所述权限申请结果。
4.根据权利要求3所述的方法,其特征在于,所述申请请求中携带申请标识码,且所述权限委托类中存储有所述申请请求中携带的申请标识码;所述权限申请结果也携带申请标识码;
所述方法还包括:
所述Fragment/Activity框架调用所述onActivityResult函数,向所述权限委托类回传所述权限申请结果中的申请标识码;
所述权限委托类调用所述onRequestPermissionsResult函数接收所述权限申请结果中的申请标识码;
所述权限委托类判断接收的申请标识码与所述权限委托类中存储的申请标识码是否相同;
在接收的申请标识码与所述权限委托类中存储的申请标识码相同的情况下,所述权限委托类调用所述onRequestPermissionsResult函数向所述Fragment/Activity框架发送用于请求接收所述权限申请结果的接收请求;
所述Fragment/Activity框架调用onActivityResult函数接收所述接收请求,再根据所述接收请求执行所述调用所述Fragment/Activity框架中的onActivityResult函数,向所述权限委托类回传所述权限申请结果的步骤。
5.根据权利要求1所述的方法,其特征在于,所述原生页面调用所述权限委托类得到的所述权限申请结果,包括:
所述原生页面调用PermissionsResultaction函数来获取所述权限委托类得到的所述权限申请结果。
6.一种信息处理装置,其特征在于,应用于电子设备,所述装置包括:
第一调用模块,用于在原生页面需要向所述电子设备的操作系统申请权限的情况下,调用集成在所述原生页面中的Fragment/Activity框架的权限委托类;
第一发送模块,用于向所述操作系统的授权页面发送用于申请权限的申请请求;
第一接收模块,用于接收所述申请请求;
第二发送模块,用于根据所述申请请求向所述权限委托类发送权限申请结果;
第二接收模块,用于接收所述授权页面返回的所述权限申请结果;
第二调用模块,用于调用所述权限委托类得到的所述权限申请结果。
7.根据权利要求6所述的装置,其特征在于,所述第一发送模块包括:
第一发送单元,用于调用requestPermissions函数向所述操作系统中的包管理器发送用于获取所述授权页面的页面地址的获取请求;
第一接收单元,用于接收所述获取请求;
第二发送单元,用于向所述权限委托类发送所述页面地址;
第二接收单元,用于调用requestPermissions函数接收所述页面地址,并根据所述页面地址向所述授权页面发送所述申请请求。
8.根据权利要求6所述的装置,其特征在于,所述第二发送模块包括:
第一回传单元,用于根据所述申请请求调用所述Fragment/Activity框架中的dispatchActivityResult函数,向所述Fragment/Activity框架回传所述权限申请结果;
第二回传单元,用于调用所述Fragment/Activity框架中的onActivityResult函数,向所述权限委托类回传所述权限申请结果。
9.根据权利要求8所述的装置,其特征在于,所述申请请求中携带申请标识码,且所述权限委托类中存储有所述申请请求中携带的申请标识码;所述权限申请结果也携带申请标识码;
所述第二发送模块还包括:
第三回传单元,用于调用所述onActivityResult函数,向所述权限委托类回传所述权限申请结果中的申请标识码;
第三接收单元,用于调用所述onRequestPermissionsResult函数接收所述权限申请结果中的申请标识码;
判断单元,用于判断接收的申请标识码与所述权限委托类中存储的申请标识码是否相同;
第三发送单元,用于在接收的申请标识码与所述权限委托类中存储的申请标识码相同的情况下,调用所述onRequestPermissionsResult函数向所述Fragment/Activity框架发送用于请求接收所述权限申请结果的接收请求;
第四接收单元,用于调用onActivityResult函数接收所述接收请求;
所述第二回传单元还用于根据所述接收请求调用所述Fragment/Activity框架中的onActivityResult函数,向所述权限委托类回传所述权限申请结果。
10.根据权利要求6所述的装置,其特征在于,所述第二调用模块具体用于:调用PermissionsResultaction函数来获取所述权限委托类得到的所述权限申请结果。
11.一种电子设备,其特征在于,所述电子设备包括:
处理器;
用于存储处理器可执行指令的存储器;
其中,所述处理器被配置为执行如权利要求1-5任一项所述的信息处理方法。
12.一种非临时性计算机可读存储介质,当所述存储介质中的指令由电子设备的处理器执行时,使得电子设备能够执行如权利要求1-5任一项所述的信息处理方法。
Priority Applications (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN202011590241.8A CN112651012B (zh) | 2020-12-28 | 2020-12-28 | 一种信息处理方法及装置 |
Applications Claiming Priority (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN202011590241.8A CN112651012B (zh) | 2020-12-28 | 2020-12-28 | 一种信息处理方法及装置 |
Publications (2)
Publication Number | Publication Date |
---|---|
CN112651012A true CN112651012A (zh) | 2021-04-13 |
CN112651012B CN112651012B (zh) | 2023-03-24 |
Family
ID=75363664
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
CN202011590241.8A Active CN112651012B (zh) | 2020-12-28 | 2020-12-28 | 一种信息处理方法及装置 |
Country Status (1)
Country | Link |
---|---|
CN (1) | CN112651012B (zh) |
Cited By (1)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN116150794A (zh) * | 2023-04-14 | 2023-05-23 | 深圳依时货拉拉科技有限公司 | 权限处理方法、装置、电子设备及存储介质 |
Citations (6)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US20090144707A1 (en) * | 2007-12-04 | 2009-06-04 | Goff Robert E | Method for client-side aggregation of asynchronous, context-sensitive request operations for java server pages (jsp) |
CN104134036A (zh) * | 2014-07-26 | 2014-11-05 | 珠海市君天电子科技有限公司 | 一种获取Root权限的方法及装置 |
CN110187932A (zh) * | 2019-05-23 | 2019-08-30 | 北京普天太力通信科技有限公司 | 一种业务数据页面加载方法及系统 |
CN111027051A (zh) * | 2019-10-29 | 2020-04-17 | 贝壳技术有限公司 | 控制页面权限调用的方法、装置及可读存储介质 |
CN111444453A (zh) * | 2020-02-27 | 2020-07-24 | 中国平安人寿保险股份有限公司 | 页面回传数据处理方法及其装置 |
CN111797025A (zh) * | 2020-07-17 | 2020-10-20 | 北京中指讯博数据信息技术有限公司 | 一种针对应用的数据处理方法及装置 |
-
2020
- 2020-12-28 CN CN202011590241.8A patent/CN112651012B/zh active Active
Patent Citations (6)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US20090144707A1 (en) * | 2007-12-04 | 2009-06-04 | Goff Robert E | Method for client-side aggregation of asynchronous, context-sensitive request operations for java server pages (jsp) |
CN104134036A (zh) * | 2014-07-26 | 2014-11-05 | 珠海市君天电子科技有限公司 | 一种获取Root权限的方法及装置 |
CN110187932A (zh) * | 2019-05-23 | 2019-08-30 | 北京普天太力通信科技有限公司 | 一种业务数据页面加载方法及系统 |
CN111027051A (zh) * | 2019-10-29 | 2020-04-17 | 贝壳技术有限公司 | 控制页面权限调用的方法、装置及可读存储介质 |
CN111444453A (zh) * | 2020-02-27 | 2020-07-24 | 中国平安人寿保险股份有限公司 | 页面回传数据处理方法及其装置 |
CN111797025A (zh) * | 2020-07-17 | 2020-10-20 | 北京中指讯博数据信息技术有限公司 | 一种针对应用的数据处理方法及装置 |
Cited By (1)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN116150794A (zh) * | 2023-04-14 | 2023-05-23 | 深圳依时货拉拉科技有限公司 | 权限处理方法、装置、电子设备及存储介质 |
Also Published As
Publication number | Publication date |
---|---|
CN112651012B (zh) | 2023-03-24 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
EP3188066B1 (en) | A method and an apparatus for managing an application | |
US20170171321A1 (en) | Methods and devices for managing accounts | |
CN108702763B (zh) | 前导码和调度请求的发送方法及装置 | |
CN106126025B (zh) | 复制粘贴的交互方法及装置 | |
CN109669730B (zh) | 一种进程保活方法、装置、电子设备及介质 | |
CN107147815B (zh) | 基于打车的通话处理方法和装置 | |
CN105100074A (zh) | 数据操作处理方法、装置以及终端设备 | |
CN105427161A (zh) | 一种货币汇率转换的方法及装置 | |
CN107239351B (zh) | 粘贴方法及装置 | |
CN105049219B (zh) | 流量订购方法和系统、移动终端及服务器 | |
CN105956486A (zh) | 远程控制方法及装置 | |
CN113596175A (zh) | 场景同步方法、终端、服务器及系统 | |
CN105577523A (zh) | 消息发送方法及装置 | |
CN112651012B (zh) | 一种信息处理方法及装置 | |
CN105376318A (zh) | 文件传输方法、装置及系统 | |
CN106034214A (zh) | 视频数据录制方法及装置 | |
CN105786561B (zh) | 进程调用的方法及装置 | |
CN107885464B (zh) | 数据存储方法、装置及计算机可读存储介质 | |
CN110764847A (zh) | 用户信息处理方法、装置、电子设备及存储介质 | |
CN107395724B (zh) | 网络请求方法及装置 | |
CN113778687B (zh) | 内存分配信息处理方法、装置、电子设备及存储介质 | |
CN105607958B (zh) | 信息输入方法及装置 | |
CN110457084B (zh) | 一种加载方法及装置 | |
CN112769677A (zh) | 数据同步方法、装置、电子设备、存储介质和程序产品 | |
CN108011882B (zh) | 一种进行数据同步的方法、装置和系统 |
Legal Events
Date | Code | Title | Description |
---|---|---|---|
PB01 | Publication | ||
PB01 | Publication | ||
SE01 | Entry into force of request for substantive examination | ||
SE01 | Entry into force of request for substantive examination | ||
GR01 | Patent grant | ||
GR01 | Patent grant |