recherche
Maisondéveloppement back-endtutoriel php运用phprpc协议实现Android客户端的一些总结

应用phprpc协议实现Android客户端的一些总结

本来这篇文章会放Android版本做完就写的~结果由于一系列的事情而耽搁掉了,下面是我在使用phprpc协议编写android应用时出现的问题的一些心得总结。

?

1、登陆机制及客户端同步问题

服务端是由phprpc提供的远程调用接口,当然首先要开启android的互联网访问权限:

?

<uses-permission android:name="android.permission.INTERNET"></uses-permission>

?

? 在AndroidManifest.xml插入以上语句,哎。。。这个语句害小弟查了半天啊。。。程序编好居然一直没法显示内容一查才知道少了这个权限,打死我也不会忘了它~~

?

接着因为服务端用的是会话保存HashCode形式的登录验证模式。就是说在客户端中一直公用同一个客户端对象和HashCode,在Android不能像Web应用一样使用Session或Cookie跨页面全局变量,如以前有一篇我写的博文写的可以用Android自带的全局对象。创建如下代码:

?

import org.phprpc.PHPRPC_Client;import android.app.Application;public class ShareContext extends Application {	private PHPRPC_Client client = null;	private String source = null;	public String getSource() {		return source;	}	public void setSource(String source) {		this.source = source;	}	public PHPRPC_Client getClient() {		return client;	}	public void setClient(PHPRPC_Client client) {		this.client = client;	}}

?

? 上面就是公用的客户端对象和HashCode,并在AndroidManifest.xml中更改下列代码:

?

<application android:name=".ShareContext" android:icon="@drawable/icon" android:label="@string/app_name"></application>

?

? 上面的android:name=".ShareContext"这句话就是声明一个context上下文全局变量,再详细的参见那篇博文。

初次登陆初始化上下文对象:

?

shareContext = ((ShareContext)getApplicationContext());		this.client = shareContext.getClient();		this.source = shareContext.getSource();				if(this.client == null){						Intent it = getIntent();	        String accountStr = it.getStringExtra("accountStr").toString();	        String passwordStr = it.getStringExtra("passwordStr").toString();	        	        this.client = new PHPRPC_Client(SERVICE_URL);  	        this.client.setEncryptMode(2);  	        	        this.source = Cast.toString(client.invoke("check_login", new Object[]{accountStr,passwordStr}));	        	        if(this.source == null){	        	Log.e("flowg_error", "source not find!");	        	Toast.makeText(getApplicationContext(), "验证错误",Toast.LENGTH_SHORT).show();	        }else{	        	client.useService(SERVICE_URL);		        shareContext.setClient(this.client);		        shareContext.setSource(this.source);	        }	        	        Object s = client.invoke("selfuser_timeline", new Object[]{source,0,20});			Log.v("source0",s.toString());	       		}

?

? 之后就可以在其他Activity中取出上下文对象中这两个属性了:

?

	shareContext = ((ShareContext)getApplicationContext());    	client = shareContext.getClient();    	source = shareContext.getSource();

? 在其后就能正式的使用它们了。

?

?

2、关于远程调用传输的数组序列化问题

在phprpc中虽然传输的是php编译化hash码,但客户端调用后回调中的一般会转化为现有系统无法识别的数组,对于php服务端传输过了是一个索引数组,而在java端是没有索引数组这一说的,准确是一个经过处理的HashMap,刚开始还不知道phprpc库有提供数组序列化解析库,一直取不出里面的值(协议库相当不错,但api文档做的貌似差了点),搞phprpc就是看源码来弄,api什么的只是入个门,在看源码时候发现有AssocArray这样一个库自带索引数组类。。。好吧,继续。。。

现在问题就解决了,看下面代码:

?

this.list = new ArrayList<topicinfo>();AssocArray alist = (AssocArray)client.invoke("home_timeline", new Object[]{this.source,0,20});for(int i = 0 ; i <p>在对于invoke远程调用时返回数组直接格式化为<span style="white-space: pre;">AssocArray类,接下来就能像使用HashMap一样使用get方法取出数据了,这个索引数组类并不是继承HashMap,而是将HashMap作为内部属性</span></p>
<p>,就是说phprpc库对LinkedHashMap链式HashMap做了一层外层封装,里面的方法基本和HashMap差不多,具体可以看源码。</p>
<p>?</p>
<p><span style="white-space: pre;">	</span>3、远程调用字符串的格式化</p>
<p><span style="white-space: pre;">	</span>这个问题貌似在网上有很多人提问。。。看了这个api文档真的得修正修正了,其实分析了源文件源码后会发现原来phprpc还是提供解析类,这个类就是Cast,</p>
<p>直接调用下面的静态方法便可以搞定:</p>
<p>?</p>
<pre name="code" class="java">Cast.toString(a.get("nickname"));

?

小结:感觉phprpc的api文档真的做的不咋的。。有待完善,害得我有问题就要看库源码,不过感觉android平台下使用phprpc应该和java下没有什么区别,刚开始的xml配置丢失搞的我很懊恼啊,而其中的格式化数组字符串什么的也折腾了好久。。。善哉善哉。。。

Déclaration
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn
Quels sont les problèmes courants qui peuvent faire échouer les sessions de PHP?Quels sont les problèmes courants qui peuvent faire échouer les sessions de PHP?Apr 25, 2025 am 12:16 AM

Les raisons de la défaillance de la phpsession comprennent les erreurs de configuration, les problèmes de cookies et l'expiration de session. 1. Erreur de configuration: vérifiez et définissez la session correcte.save_path. 2.Cookie Problème: assurez-vous que le cookie est correctement réglé. 3.Session Expire: Ajustez la valeur de session.gc_maxlifetime pour prolonger le temps de session.

Comment déboguez-vous les problèmes liés à la session dans PHP?Comment déboguez-vous les problèmes liés à la session dans PHP?Apr 25, 2025 am 12:12 AM

Les méthodes pour déboguer les problèmes de session en PHP incluent: 1. Vérifiez si la session est démarrée correctement; 2. Vérifiez la livraison de l'ID de session; 3. Vérifiez le stockage et la lecture des données de session; 4. Vérifiez la configuration du serveur. En sortissant l'ID de session et les données, en affichant le contenu du fichier de session, etc., vous pouvez diagnostiquer et résoudre efficacement les problèmes liés à la session.

Que se passe-t-il si Session_Start () est appelé plusieurs fois?Que se passe-t-il si Session_Start () est appelé plusieurs fois?Apr 25, 2025 am 12:06 AM

Plusieurs appels vers session_start () se traduiront par des messages d'avertissement et d'éventuels remplacements de données. 1) PHP émettra un avertissement, ce qui incite la session à démarrer. 2) Il peut provoquer un écrasement inattendu des données de session. 3) Utilisez session_status () pour vérifier l'état de la session pour éviter les appels répétés.

Comment configurez-vous la durée de vie de la session en PHP?Comment configurez-vous la durée de vie de la session en PHP?Apr 25, 2025 am 12:05 AM

La configuration du cycle de vie de session dans PHP peut être réalisée en définissant session.gc_maxlifetime et session.cookie_lifetime. 1) Session.gc_maxlifetime contrôle le temps de survie des données de session côté serveur, 2) Session.cookie_lifetime contrôle le cycle de vie des cookies des clients. Lorsqu'il est réglé sur 0, le cookie expire lorsque le navigateur est fermé.

Quels sont les avantages de l'utilisation d'une base de données pour stocker des sessions?Quels sont les avantages de l'utilisation d'une base de données pour stocker des sessions?Apr 24, 2025 am 12:16 AM

Les principaux avantages de l'utilisation des sessions de stockage de la base de données incluent la persistance, l'évolutivité et la sécurité. 1. Persistance: Même si le serveur redémarre, les données de session peuvent rester inchangées. 2. Évolutivité: applicable aux systèmes distribués, garantissant que les données de session sont synchronisées entre plusieurs serveurs. 3. Sécurité: La base de données fournit un stockage crypté pour protéger les informations sensibles.

Comment implémentez-vous la gestion des sessions personnalisées dans PHP?Comment implémentez-vous la gestion des sessions personnalisées dans PHP?Apr 24, 2025 am 12:16 AM

L'implémentation de traitement personnalisé de session dans PHP peut être effectué en implémentant l'interface SessionHandlerInterface. Les étapes spécifiques incluent: 1) la création d'une classe qui implémente SessionHandlerInterface, telles que CustomSessionHandler; 2) réécrire des méthodes dans l'interface (telles que l'ouverture, la fermeture, la lecture, l'écriture, la détruire, GC) pour définir le cycle de vie et la méthode de stockage des données de session; 3) Enregistrez un processeur de session personnalisé dans un script PHP et démarrez la session. Cela permet de stocker des données dans des supports tels que MySQL et Redis pour améliorer les performances, la sécurité et l'évolutivité.

Qu'est-ce qu'un identifiant de session?Qu'est-ce qu'un identifiant de session?Apr 24, 2025 am 12:13 AM

SessionID est un mécanisme utilisé dans les applications Web pour suivre l'état de la session utilisateur. 1. Il s'agit d'une chaîne générée aléatoire utilisée pour maintenir les informations d'identité de l'utilisateur lors de plusieurs interactions entre l'utilisateur et le serveur. 2. Le serveur génère et l'envoie au client via des cookies ou des paramètres d'URL pour aider à identifier et à associer ces demandes dans plusieurs demandes de l'utilisateur. 3. La génération utilise généralement des algorithmes aléatoires pour assurer l'unicité et l'imprévisibilité. 4. Dans le développement réel, les bases de données en mémoire telles que Redis peuvent être utilisées pour stocker les données de session pour améliorer les performances et la sécurité.

Comment gérez-vous les sessions dans un environnement sans état (par exemple, API)?Comment gérez-vous les sessions dans un environnement sans état (par exemple, API)?Apr 24, 2025 am 12:12 AM

La gestion des séances dans des environnements sans état tels que les API peut être réalisée en utilisant JWT ou des cookies. 1. JWT convient à l'état sans état et à l'évolutivité, mais il est de grande taille en ce qui concerne les mégadonnées. 2.La cookies est plus traditionnel et facile à mettre en œuvre, mais ils doivent être configurés avec prudence pour assurer la sécurité.

See all articles

Outils d'IA chauds

Undresser.AI Undress

Undresser.AI Undress

Application basée sur l'IA pour créer des photos de nu réalistes

AI Clothes Remover

AI Clothes Remover

Outil d'IA en ligne pour supprimer les vêtements des photos.

Undress AI Tool

Undress AI Tool

Images de déshabillage gratuites

Clothoff.io

Clothoff.io

Dissolvant de vêtements AI

Video Face Swap

Video Face Swap

Échangez les visages dans n'importe quelle vidéo sans effort grâce à notre outil d'échange de visage AI entièrement gratuit !

Outils chauds

Dreamweaver Mac

Dreamweaver Mac

Outils de développement Web visuel

VSCode Windows 64 bits Télécharger

VSCode Windows 64 bits Télécharger

Un éditeur IDE gratuit et puissant lancé par Microsoft

SublimeText3 version Mac

SublimeText3 version Mac

Logiciel d'édition de code au niveau de Dieu (SublimeText3)

Navigateur d'examen sécurisé

Navigateur d'examen sécurisé

Safe Exam Browser est un environnement de navigation sécurisé permettant de passer des examens en ligne en toute sécurité. Ce logiciel transforme n'importe quel ordinateur en poste de travail sécurisé. Il contrôle l'accès à n'importe quel utilitaire et empêche les étudiants d'utiliser des ressources non autorisées.

Dreamweaver CS6

Dreamweaver CS6

Outils de développement Web visuel