为什么扩展的 ascii 字符(â、é 等)被替换为 ?> 字符?
我附上了一张图片...但我正在使用 PHP 从 MySQL 中提取数据,其中一些位置有扩展字符...我使用的是 Arial 字体。
您可以在此处查看屏幕截图:http://img269.imageshack.us/i/funnychar.png/
在建议之后仍然发生,这是我所做的:
添加该行后,我的 firefox( View -> 编码)设置为 UTF-8,但是,选项标签内的文本仍然显示有趣的字符,而不是实际的重音字符。我现在应该寻找什么?
更新: 我在 PHP 程序中有以下内容给我那些 ?> 字符...
ini_set( 'default_charset', 'UTF-8' );
在创建 zend db 对象之后,我设置了以下查询:
$db->query("SET NAMES utf8;");
我将所有表格更改为 UTF-8 并重新插入所有数据(浪费时间),因为它毫无帮助。之前是 latin1。
还有 STATUS 正在报告:
Connection: Localhost via UNIX socket
Server characterset: latin1
Db characterset: latin1
Client characterset: utf8
Conn. characterset: utf8
UNIX socket: /var/run/mysqld/mysqld.sock
Uptime: 4 days 20 hours 59 min 41 sec
查看页面的源代码,我明白了
确定- 新更新- 我将 PHP 和 HTML 中的所有内容更改为:
和
header('Content-Type: text/html; charset=latin1');
现在可以用了,是什么原因?如何将其全部转换为 UTF-8?
最佳答案
这就是浏览器在不知道用于字符的编码时所做的事情。确保在 header 或标记元中指定发送给客户端的文本的编码类型。
在 HTML 中:
<meta http-equiv="Content-Type" content="text/html; charset=utf-8">
在 PHP 中(在任何其他内容发送到客户端之前):
header('Content-Type: text/html; charset=utf-8');
我假设您需要 UTF-8 编码。如果您的网站使用另一种文本编码,则应将 UTF-8 替换为您正在使用的编码。
关于使用 HTML 指定编码需要注意的一件事是浏览器在看到 Content-Type 后将重新开始呈现页面。元标记,因此您应该包含 <meta />紧跟在 <head /> 之后的标签在您的页面中添加标记,以便浏览器不会执行超出其需要的额外处理。
另一个常见的字符集是“iso-8859-1”(基本拉丁语),您可能希望使用它来代替 UTF-8。您可以从这篇关于 character encodings and the web 的精彩文章中找到更多详细信息。 .您还可以获得详尽的 list of character encodings here如果您需要特定类型。
如果其他方法均无效,另一种(罕见的)可能性是您的计算机上可能没有安装具有显示页面所需字符的字体。我试过了 repeating your results on my own server运气不好,可能是因为我的机器上安装了很多字体,所以浏览器总是可以用另一种字体替换一种字体中不可用的字符。
我通过进一步调查确实注意到,如果发送的文本编码与浏览器报告的编码不同,Unicode 字符可能会意外呈现。为了解决这个问题,我使用了 HTML character entity representation特殊字符,所以 â变成 â在我的 HTML 和 é变成 é .执行此操作后,无论我报告的编码是什么,我的字符都会正确呈现。
显然,您不想修改数据库以使用 HTML 编码 Unicode 字符。如果必须这样做,最好的选择是使用 PHP 函数 htmlentities() .您应该在任何希望包含 Unicode 字符的数据驱动文本上使用此函数。这样做可能很烦人,但如果指定编码没有帮助,这是强制 Unicode 字符工作的最后一招。
关于php - 为什么这个扩展的 ascii 字符(â、é 等)被替换为 <?> 字符?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/1028449/
总的来说,我对ruby还比较陌生,我正在为我正在创建的对象编写一些rspec测试用例。许多测试用例都非常基础,我只是想确保正确填充和返回值。我想知道是否有办法使用循环结构来执行此操作。不必为我要测试的每个方法都设置一个assertEquals。例如:describeitem,"TestingtheItem"doit"willhaveanullvaluetostart"doitem=Item.new#HereIcoulddotheitem.name.shouldbe_nil#thenIcoulddoitem.category.shouldbe_nilendend但我想要一些方法来使用
我有一个字符串input="maybe(thisis|thatwas)some((nice|ugly)(day|night)|(strange(weather|time)))"Ruby中解析该字符串的最佳方法是什么?我的意思是脚本应该能够像这样构建句子:maybethisissomeuglynightmaybethatwassomenicenightmaybethiswassomestrangetime等等,你明白了......我应该一个字符一个字符地读取字符串并构建一个带有堆栈的状态机来存储括号值以供以后计算,还是有更好的方法?也许为此目的准备了一个开箱即用的库?
类classAprivatedeffooputs:fooendpublicdefbarputs:barendprivatedefzimputs:zimendprotecteddefdibputs:dibendendA的实例a=A.new测试a.foorescueputs:faila.barrescueputs:faila.zimrescueputs:faila.dibrescueputs:faila.gazrescueputs:fail测试输出failbarfailfailfail.发送测试[:foo,:bar,:zim,:dib,:gaz].each{|m|a.send(m)resc
我的目标是转换表单输入,例如“100兆字节”或“1GB”,并将其转换为我可以存储在数据库中的文件大小(以千字节为单位)。目前,我有这个:defquota_convert@regex=/([0-9]+)(.*)s/@sizes=%w{kilobytemegabytegigabyte}m=self.quota.match(@regex)if@sizes.include?m[2]eval("self.quota=#{m[1]}.#{m[2]}")endend这有效,但前提是输入是倍数(“gigabytes”,而不是“gigabyte”)并且由于使用了eval看起来疯狂不安全。所以,功能正常,
在我的Rails(2.3,Ruby1.8.7)应用程序中,我需要将字符串截断到一定长度。该字符串是unicode,在控制台中运行测试时,例如'א'.length,我意识到返回了双倍长度。我想要一个与编码无关的长度,以便对unicode字符串或latin1编码字符串进行相同的截断。我已经了解了Ruby的大部分unicode资料,但仍然有些一头雾水。应该如何解决这个问题? 最佳答案 Rails有一个返回多字节字符的mb_chars方法。试试unicode_string.mb_chars.slice(0,50)
我有一个模型:classItem项目有一个属性“商店”基于存储的值,我希望Item对象对特定方法具有不同的行为。Rails中是否有针对此的通用设计模式?如果方法中没有大的if-else语句,这是如何干净利落地完成的? 最佳答案 通常通过Single-TableInheritance. 关于ruby-on-rails-Rails-子类化模型的设计模式是什么?,我们在StackOverflow上找到一个类似的问题: https://stackoverflow.co
对于具有离线功能的智能手机应用程序,我正在为Xml文件创建单向文本同步。我希望我的服务器将增量/差异(例如GNU差异补丁)发送到目标设备。这是计划:Time=0Server:hasversion_1ofXmlfile(~800kiB)Client:hasversion_1ofXmlfile(~800kiB)Time=1Server:hasversion_1andversion_2ofXmlfile(each~800kiB)computesdeltaoftheseversions(=patch)(~10kiB)sendspatchtoClient(~10kiBtransferred)Cl
大约一年前,我决定确保每个包含非唯一文本的Flash通知都将从模块中的方法中获取文本。我这样做的最初原因是为了避免一遍又一遍地输入相同的字符串。如果我想更改措辞,我可以在一个地方轻松完成,而且一遍又一遍地重复同一件事而出现拼写错误的可能性也会降低。我最终得到的是这样的:moduleMessagesdefformat_error_messages(errors)errors.map{|attribute,message|"Error:#{attribute.to_s.titleize}#{message}."}enddeferror_message_could_not_find(obje
我试图获取一个长度在1到10之间的字符串,并输出将字符串分解为大小为1、2或3的连续子字符串的所有可能方式。例如:输入:123456将整数分割成单个字符,然后继续查找组合。该代码将返回以下所有数组。[1,2,3,4,5,6][12,3,4,5,6][1,23,4,5,6][1,2,34,5,6][1,2,3,45,6][1,2,3,4,56][12,34,5,6][12,3,45,6][12,3,4,56][1,23,45,6][1,2,34,56][1,23,4,56][12,34,56][123,4,5,6][1,234,5,6][1,2,345,6][1,2,3,456][123
我正在使用的第三方API的文档状态:"[O]urAPIonlyacceptspaddedBase64encodedstrings."什么是“填充的Base64编码字符串”以及如何在Ruby中生成它们。下面的代码是我第一次尝试创建转换为Base64的JSON格式数据。xa=Base64.encode64(a.to_json) 最佳答案 他们说的padding其实就是Base64本身的一部分。它是末尾的“=”和“==”。Base64将3个字节的数据包编码为4个编码字符。所以如果你的输入数据有长度n和n%3=1=>"=="末尾用于填充n%