php-从Android手机向在线MySQl数据库发送阿拉伯文本
内容导读
互联网集市收集整理的这篇技术教程文章主要介绍了php-从Android手机向在线MySQl数据库发送阿拉伯文本,小编现在分享给大家,供广大互联网技能从业者学习和参考。文章包含2488字,纯文字阅读大概需要4分钟。
内容图文
![php-从Android手机向在线MySQl数据库发送阿拉伯文本](/upload/InfoBanner/zyjiaocheng/885/c7728759d524459ea32236e823577425.jpg)
我制作了一个应用程序,该应用程序将很少的文本输入从android发送到我的在线数据库.我的应用程序运行良好,但是一些用户报告说他们不能使用阿拉伯文字.所以我尝试了一下,当我在数据库中发送阿拉伯文本时,它显示为?????. ?????? ??????
我的PHP脚本:
<?php
$connect = mysql_connect($db_host,$db_uid,$db_pass) or die('could not connect');
mysql_select_db($db_name);
if(mysql_errno($connect))
{
die("Failed to connect to MySQL: " . mysql_error());
}
else
{
echo "success";
mysql_query("SET NAMES 'utf8'"); mysql_query('SET CHARACTER SET utf8');
}
$name = isset($_POST['name']) ? $_POST['name'] : '';
$sex = isset($_POST['sex']) ? $_POST['sex'] : '';
$nationality = isset($_POST['nationality']) ? $_POST['nationality'] : '';
$query = mysql_query( "insert into people (name, sex, nationality) values (N'$name' ,N'$sex', N'$nationality') ", $connect);
print_r($_POST);
if(!$query) echo mysql_error();
mysql_close($connect);
?>
我的Android代码:
DefaultHttpClient httpclient= new DefaultHttpClient();
HttpPost httppost = new HttpPost("http://www.xxxxxxxx.com/thescript.php");
Log.e("done 1st","its here");
try
{
ArrayList<NameValuePair> nameValuePairs = new ArrayList<NameValuePair>();
nameValuePairs.add(new BasicNameValuePair("name", Name.getText().toString()));
nameValuePairs.add(new BasicNameValuePair("sex", Sex.getText().toString()));
nameValuePairs.add(new BasicNameValuePair("nationality", Nationality.getText().toString()));
httppost.setEntity(new UrlEncodedFormEntity(nameValuePairs));
HttpResponse response = httpclient.execute(httppost);
Log.e("done", String.valueOf(response));
}
如您所见,我尝试了很少的东西,但没有一个起作用.
当使用插入到在线pc .php中时,我会得到这样的信息:
———
我的数据库设置为:
表排序规则是utf8_general_ci
它的类型是MyISAM
以及其中的列(姓名,性别,国籍):
类型是varchar,排序规则是utf8_general_ci
例如
输出应该是???,但它是???
解决方法:
这样做
DefaultHttpClient httpclient= new DefaultHttpClient();
HttpPost httppost = new HttpPost("http://www.xxxxxxxx.com/thescript.php");
Log.e("done 1st","its here");
try
{
ArrayList<NameValuePair> nameValuePairs = new ArrayList<NameValuePair>();
nameValuePairs.add(new BasicNameValuePair("name", Name.getText().toString()));
nameValuePairs.add(new BasicNameValuePair("sex", Sex.getText().toString()));
nameValuePairs.add(new BasicNameValuePair("nationality", Nationality.getText().toString()));
httppost.setEntity(new UrlEncodedFormEntity(nameValuePairs, "UTF-8")); //UPDATE HERE
HttpResponse response = httpclient.execute(httppost);
Log.e("done", String.valueOf(response));
}
内容总结
以上是互联网集市为您收集整理的php-从Android手机向在线MySQl数据库发送阿拉伯文本全部内容,希望文章能够帮你解决php-从Android手机向在线MySQl数据库发送阿拉伯文本所遇到的程序开发问题。 如果觉得互联网集市技术教程内容还不错,欢迎将互联网集市网站推荐给程序员好友。
内容备注
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 gblab@vip.qq.com 举报,一经查实,本站将立刻删除。
内容手机端
扫描二维码推送至手机访问。