***解决PHP输出多余的空格或换行

用CI框架写APP后台接口的时候,返回的JSON前面有多余的2哥换行,首先排查的是BOM,结果问题依旧

再就是排查<?php ?> 标签外没有多余的回车、换行,结果发现确实有多余的换行,去掉之后,问题消失。

总结:建议去掉PHP结束标签,这样会避免很多莫名其妙的问题

写代码的童鞋应该知道,经常会在前端看到页面不能置顶,即使加了再多的样式,都不行,那就可以考虑一下是否为下面几种情况了:

1、确认代码没有 echo 或者 exit 空格、换行;

2、确保 php 文件里 <?php ?> 标签外没有多余的回车、换行;

3、以上两点都排查之后,如果你的代码文件为 UTF8 编码文件,那可以考虑可能是由于 BOM 文件头造成的,可以使用任何一款非微软制作的文本编辑器(如Notepad++、ultraedit等)打开文件,另存为无BOM的文件,如果文件太多,可以将以下代码保存并放到根目录下执行一次即可!

<?php
//remove the utf-8 boms
if (isset($_GET[‘dir‘])){
	//config the basedir
	$basedir=$_GET[‘dir‘];
}else{
	$basedir = ‘.‘;
}

$auto = 1;
checkdir($basedir);
function checkdir($basedir){
	if ($dh = opendir($basedir)) {
		while (($file = readdir($dh)) !== false) {
			if ($file != ‘.‘ && $file != ‘..‘){
				if (!is_dir($basedir."/".$file)) {
					echo "filename: $basedir/$file ".checkBOM("$basedir/$file")." <br>";
				}else{
					$dirname = $basedir."/".$file;
					checkdir($dirname);
				}
			}
		}
		closedir($dh);
	}
}

function checkBOM ($filename) {
	global $auto;
	$contents = file_get_contents($filename);
	$charset[1] = substr($contents, 0, 1);
	$charset[2] = substr($contents, 1, 1);
	$charset[3] = substr($contents, 2, 1);
	if (ord($charset[1]) == 239 && ord($charset[2]) == 187 && ord($charset[3]) == 191) {
		if ($auto == 1) {
			$rest = substr($contents, 3);
			rewrite ($filename, $rest);
			return ("<font color=red>BOM found, automatically removed.</font>");
		} else {
			return ("<font color=red>BOM found.</font>");
		}
	}
	else return ("BOM Not Found.");
}

function rewrite ($filename, $data) {
	$filenum = fopen($filename, "w");
	flock($filenum, LOCK_EX);
	fwrite($filenum, $data);
	fclose($filenum);
}
?>

php bom去除工具,php批量去除bom的代码

php批量去除文件bom代码的功能,支持文件夹批量去除。具体php文件代码如下:

查看代码

打印

01 <?php
02 header(‘content-Type: text/html; charset=utf-8‘);
03 $auto=1;/*设置为1标示检测BOM并去除,设置为0标示只进行BOM检测,不去除*/
04 $basedir=‘.‘;
05 $loop=true;//www.phpernote.com
06 echo ‘当前查找的目录为:‘.$basedir.‘当前的设置是:‘;
07 echo ‘(1)‘,$loop?‘检查当前目录以及当前目录的子目录‘:‘只针对当前目录进行检测‘;
08 echo ‘(2)‘,$auto?‘检测文件BOM同时去除检测到BOM文件的BOM<br />‘:‘只检测文件BOM不执行去除BOM操作<br />‘;
09  
10 checkdir($basedir,$loop);
11 function checkdir($basedir=‘‘,$loop=true){
12     $basedir=empty($basedir)?‘.‘:$basedir;
13     if($dh=opendir($basedir)){
14         while (($file=readdir($dh))!==false){
15             if($file!=‘.‘&&$file!=‘..‘){
16                 if(!is_dir($basedir.‘/‘.$file)){
17                     echo ‘文件: ‘.$basedir.‘/‘.$file .checkBOM($basedir.‘/‘.$file).‘ <br>‘;
18                 }else{
19                     if(!$loopcontinue;
20                     $dirname=$basedir.‘/‘.$file;
21                     checkdir($dirname);
22                 }
23             }
24         }
25         closedir($dh);
26     }
27 }
28 function checkBOM($filename){
29     global $auto;
30     $contents=file_get_contents($filename);
31     $charset[1]=substr($contents,0,1);
32     $charset[2]=substr($contents,1,1);
33     $charset[3]=substr($contents,2,1);
34     if(ord($charset[1])==239&&ord($charset[2])==187&&ord($charset[3])==191){
35         if($auto==1){
36             $rest=substr($contents,3);
37             rewrite($filename,$rest);
38             return (‘ <font color=red>找到BOM并已自动去除</font>‘);
39         }else{
40             return (‘ <font color=red>找到BOM</font>‘);
41         }
42     }else{
43         return (‘ 没有找到BOM‘);
44     }
45 }
46 function rewrite($filename,$data){
47     $filenum=fopen($filename,‘w‘);
48     flock($filenum,LOCK_EX);
49     fwrite($filenum,$data);
50     fclose($filenum);
51 }

将以上代码保存为后缀为php的文件放到需要去除bom的文件目录里面,然后运行该php文件,将会对该目录以及该目录所有的子目录下的文件进行bom检查并去除bom,运行结果页面如下:

				
时间: 2024-08-29 19:35:09

***解决PHP输出多余的空格或换行的相关文章

shell学习过程1-如何输出a-z;空格、换行转换

有一堆主机地址:a.baidu.com...z.baidu.com如何从这些数据中提取出.baidu.com之前的字母,如:a b...z? 看到该问题,首先想到如何用脚本生成该文件: 思路: 1.定义后缀:suffix=".baidu.com" 2.输出a-z字符和后缀:{a..z}$suffix 3.空格转换行 问题1:如何输出a-z字符: 使用{a..z}输出 a b c d .....z字符间空格分隔 问题2:{a..z}$suffix 输出文本:a.baidu.com b.b

JSP输出HTML时产生的大量空格和换行的去除方法

在WEB应用中,如果使用jsp作为view层的显示模板,都会被空格/空换行问题所困扰. 方案一,利用web服务器的trimSpaces功能. Tomcat5 以上版本都可以使用,这是最简单的方法 <servlet> <servlet-name>jsp</servlet-name> <servlet-class>org.apache.jasper.servlet.JspServlet</servlet-class> <init-param&g

java压缩去除html空格和换行解决微信域名下不兼容

直接贴代码. java压缩去除html空格和换行解决微信域名下不兼容 调用:content = HtmlCompressor.compress(content); import java.io.StringReader;import java.io.StringWriter;import java.util.*;import java.util.regex.*; /******************************************* * 压缩jsp,html中的代码,去掉所有空

提交表单时如何保留多个空格及换行的文本样式

需求是:用户提交表单时屏蔽敏感词的功能.其中敏感词来自服务器端同一路径下的ciku.txt,敏感词通过"|"连接,例如"g|c|a",提交表单时替换敏感词,更重要的是,需要保持表单文本域中用户输入的多个空格及换行的样式,并原样输出.php代码如下: 1 <?php 2 header("Content-type:text/html;charset=utf-8"); 3 if($_POST){ 4 $pattern = array( 5 '/

AC日记——过滤多余的空格 1.7 23

23:过滤多余的空格 总时间限制:  1000ms 内存限制:   65536kB 描述 一个句子中也许有多个连续空格,过滤掉多余的空格,只留下一个空格. 输入 一行,一个字符串(长度不超过200),句子的头和尾都没有空格. 输出 过滤之后的句子. 样例输入 Hello world.This is c language. 样例输出 Hello world.This is c language. 思路: 大模拟: 来,上代码: #include<cstdio> #include<strin

Openjudge-计算概论(A)-过滤多余的空格

描述: 一个句子中也许有多个连续空格,过滤掉多余的空格,只留下一个空格. 输入一行,一个字符串(长度不超过200),句子的头和尾都没有空格.输出过滤之后的句子. 样例输入 Hello world.This is c language. 样例输出 Hello world.This is c language.思路:从前往后扫(一个一个的),如果非空格并且非结尾,输出那个字母,或者如果遇到空格并且下一个也是空格,输出一个空格(防止多个空格的情况),否则不变(不要在意那个“i=i*1”,就是不变的意思

ThinkPHP去掉html中的空格和换行的方法(转:http://www.111cn.net/phper/thinkPhp/91462.htm)

在thinkphp3.2.2中,出现这样一个问题:无法删除模板中的空格和换行,我们现在就来分享这个问题的解决方法,然后再补充其他的php清除空白行和换行的实例. 在thinkphp3.2.2中有无法删除模板中的空格和换行的问题: 即使配置了 'TMPL_STRIP_SPACE' => true 也是不起效的. 原因:在ThinkPHP\Library\Think\Template.class.php 文件,compiler方法少了以下的一段代码导致的: if(C('TMPL_STRIP_SPAC

百练6247-过滤多余的空格-2015正式B题

B:过滤多余的空格 总时间限制: 1000ms 内存限制:  65536kB 描述 一个句子中也许有多个连续空格,过滤掉多余的空格,只留下一个空格. 输入 一行,一个字符串(长度不超过200),句子的头和尾都没有空格. 输出 过滤之后的句子. 样例输入 Hello world.This is c language. 样例输出 Hello world.This is c language. #include <iostream> #include <stdio.h> #include

HTML &lt;pre&gt; 标签(保留空格和换行符)

pre 元素可定义预格式化的文本.被包围在 pre 元素中的文本通常会保留空格和换行符.而文本也会呈现为等宽字体. 标签的一个常见应用就是用来表示计算机的源代码.  pre 元素可定义预格式化的文本.被包围在 pre 元素中的文本通常会保留空格和换行符.而文本也会呈现为等宽字体. 标签的一个常见应用就是用来表示计算机的源代码.对于技术博客经常会用到pre标签输出代码或是代码高亮,而默认情况下,pre 标签中的内容若超出范围不会自动换行. 下面介绍一个方法让 标签中的内容自动换行并符合 W3C 标