> 백엔드 개발 > PHP 튜토리얼 > PHP 초보자 실수 세트

PHP 초보자 실수 세트

巴扎黑
풀어 주다: 2016-11-23 10:34:29
원래의
1265명이 탐색했습니다.

개발을 위해 모든 오류 프롬프트를 활성화하십시오: error_reporting = E_ALL | E_STRICT
오류 프롬프트를 차단하는 것은 귀를 숨기고 종을 훔치는 것과 같습니다.
표준화된 방식으로 코드를 작성하면 오류가 절반으로 줄어듭니다.

1: 왜 변수를 가져올 수 없나요?

한 웹 페이지에서 다른 웹 페이지로 데이터 이름을 게시했는데 $name을 출력할 때 왜 값을 얻을 수 없나요? 방법 2: extract($_POST);extract($_GET); (extract($_SESSION) 앞에 Session_Start()가 있어야 함)를 수신 웹 페이지 앞에 놓습니다.
//extract ( array $var_array [, int $extract_type [, string $prefix ]] )

//이 함수는 배열의 변수를 현재 기호 테이블로 가져오는 데 사용됩니다. 연관 배열 var_array를 인수로 받아들이고 //name 키를 변수 이름으로, 값을 변수 값으로 사용합니다. 각 키/값 쌍에 대해 //extract_type 및 prefix 매개변수의 영향을 받는 변수가 현재 기호 테이블에 생성됩니다.
//import_request_variables (string $types [, string $prefix])는 매우 전역적이며 $_ $*에 허점이 있습니다.

방법 3: 변수를 하나씩 읽기 $a=$_GET["a "];$b=$_POST["b"] 등 이 방법은 번거롭지만 더 안전합니다.

2: 프로그램 디버깅

What을 실행할 때 알아야 할 사항 변수의 값입니다. 이것이 제가 한 일입니다. 다음 내용으로 debug.php 파일을 만듭니다.

PHP 코드:------------------------- ------------------------------------- ------

코드 복사

Ob_Start();
Session_Start();
Echo "

";<br> Echo "이걸 타세요 page _GET 변수는 다음과 같습니다. ";<br> Print_R($_GET);<br> Echo "이 페이지에서 얻은 _POST 변수는 다음과 같습니다.";<br> Print_R($_POST);<br> Echo "이 페이지는 다음과 같습니다. 획득한 _COOKIE 변수는 다음과 같습니다: ";<br> Print_R($_COOKIE);<br> Echo "이 페이지에서 획득한 _SESSION 변수는 다음과 같습니다: ";<br> Print_R($_SESSION);<br> Echo "</ 사전>";<br><br><br><br>---------------------- ------------------------------------- <br><br>그런 다음 php.ini에 include_path = "c:/php"를 설정하고 이 폴더에 debug.php를 넣으세요. <br> 앞으로 모든 웹 페이지에 이 파일을 포함시키고 얻은 변수 이름을 확인할 수 있습니다. 및 값.<br><br>3: 세션 사용 방법<br><br>세션과 관련된 모든 것은 먼저 session_start() 함수를 호출해야 합니다.<br><br>세션에 대한 값을 지불하는 것은 매우 간단합니다. 예:<br><br><br>PHP 코드:---------------------- ----- --------------<br><br> php4.2 이후에는 세션 비용을 직접 지불할 수 있습니다: <br><br>PHP 코드:------------ ------- --------------<br> <br>[php]<br>Session_Start();<br>$_SESSION["name"]="value";<br>[/php]<br><br>--------- - ------------------------------------------------- - ---------<br><br>다음과 같이 세션을 취소하세요.<br><br>PHP 코드:--------- - ------------------------------------------------- - ----------<br><br>[php]<br>session_start();<br>session_unset();<br> session_destroy( );<br>[/php]<br><br>-------------------- - ------------------------------------------------<br><br><br>php4.2 이상에서는 특정 세션 변수를 취소할 때 BUG가 있습니다.<br><br><br><br>참고:<br><br>1: 있을 수 없습니다. Session_Start() 를 호출하기 전의 모든 출력. 예를 들어 다음은 잘못되었습니다.<br>=============================== =========== ==<br>1줄<br>2줄 [php]<br>3줄 Session_Start();//이미 첫 줄에 출력이 있었습니다<br>4 줄....<br>5줄[ /php]<br>================================= =========<br><br><br>팁 1:<br><br>".....헤더가 이미 전송되었습니다....."가 나타날 때마다 Session_Start() 출력 정보 이전에 브라우저에 메시지를 보냅니다.<br>출력을 제거하면 정상입니다. (이 오류는 COOKIE에서도 발생하며 오류 원인은 동일합니다.)<br><br>Tip 2:<br><br>Session_Start()가 루프 문에 배치되어 이전에 브라우저에 정보가 출력된 위치를 확인하기 어려운 경우 다음 방법을 사용할 수 있습니다. <br>1줄 [php ] Ob_Start(); [/php]<br>.....여기 있습니다 프로그램...<br><br><br><br>2: 오류가 무엇인가요<br><br>경고 : session_start(): open(/tmpsess_7d190aa36b4c5ec13a5c1649cc2da23f, O_RDWR) failed:... .<br>세션 파일의 저장 경로를 지정하지 않았기 때문입니다.<br><br>해결 방법: <br>(1) C 드라이브의 tmp 폴더<br>(2) php.ini를 열고 session.save_path= "c:/tmp"로 수정된 save_path를 찾습니다<br><br><br><br>4: 이유 변수를 다른 웹페이지로 옮기면 전반부만 가져오고 공백으로 시작하는 변수는 모두 손실됩니다. <br><br><br>PHP 코드:------------ ----------------------------- -------- --------<br><br>[php ]<br>$Var="hello php";//$Var="hello로 변경 php"; 결과를 얻으려고 노력하세요<br>$post= "receive.php?Name=".$Var;<br>헤더("location:$post");<br>[/php]<br><br>--------- ------------------------------------- --------<br><br>receive.php 내용:<br><br>PHP 코드:--------- - ------------------------------------------------- - ----------------------<br><br>[php]<br>Echo "<pre class="brush:php;toolbar:false">";<br>Echo $_GET[" 이름"];<br>에코 "
";
[/php]

---------------------- ------------------------------------- ----------


올바른 방법은 다음과 같습니다.

PHP 코드:----------------- - ------------------------------------------------- - ------------

[php]
$Var="hello php";
$post= "receive.php?Name=".urlencode( $ Var);
header("location:$post");
[/php]

------ - ------------------------------------------------- - ---------


수신 페이지에서는 Urldecode()를 사용할 필요가 없으며 변수가 자동으로 인코딩됩니다.


5: 지정된 길이의 한자를 가로채는 방법 "[/php]"로 끝나지 않고, 남는 부분은 "..."로 대체됩니다.


일반적으로 변수는 가로채려면 먼저 필드 길이가 충분한지 확인해야 합니다. 일반적으로 char(200)는 구두점을 포함하여 100자를 수용할 수 있습니다.

PHP 코드: ----- ------------------ -------------------------------- ----- -------

[php]
$str="글자가 너무 길어요^_^ ";
$Short_Str=showShort($str,4);// 처음 4개의 한자를 가로채서 결과는 다음과 같습니다.
Echo "$Short_Str";
함수 csubstr($ str,$start,$len)
{
$strlen=strlen( $str);
$clen=0;
for($i=0;$i<$strlen;$i++ ,$clen++)
{
if ($clen>=$start+$ len)
break;
if(ord(substr($str,$i,1))>0xa0)
{
if ($clen>=$start)
$tmpstr .=substr($str,$i,2);
$i++;
}
else
{
if ($clen>=$start)
$tmpstr.= substr($str,$i,1);
}
}

return $tmpstr;
}
함수 showShort($str,$len)
{
$tempstr = csubstr($str,0,$len);
if ($str<>$tempstr)
$tempstr .= "..."; //끝낼 내용, 수정은 여기서 하시면 됩니다.

return $tempstr;
}

--- --------- --------------- ---------------------- ----



6: SQL 문 표준화


오용되지 않도록 테이블과 필드 앞에 "`"를 추가하세요. 키워드로 인해 오류가 발생합니다.
당연히 키워드 사용을 권장하지 않습니다.

예를 들어
$Sql="INSERT INTO `xltxlm` (`author`, `title`, `id` , `content`, `date`) VALUES ('xltxlm', 'use`', 1, 'criterion your sql string ', '2003-07-11 00:00:00')"

" `"입력방법은? TAB키로.


7: Html 방지방법 /PHP 형식 문자열은 해석되지 않지만


PHP 코드는 그대로 표시됩니다.------------------------- ------------ ------------ ---------

[php]
$str="";
Echo "해석됨: ".$str."< ;br>처리됨:";
Echo htmlentities(nl2br($str));
[/php]

nl2br() 함수는 HTML 개행 문자(
)를 삽입합니다. 문자열의 각 새 줄(n) 앞에.
htmlentities(string,quotestyle,character-set)
 

quotestyle은 선택사항입니다. 작은따옴표와 큰따옴표가 인코딩되는 방법을 지정합니다.

ENT_COMPAT - 기본값. 큰따옴표만 인코딩됩니다.
ENT_QUOTES - 큰따옴표와 작은따옴표를 인코딩합니다.
ENT_NOQUOTES - 따옴표를 인코딩하지 마세요.

문자 집합

ISO-8859-1 - 기본값. 서유럽.
ISO-8859-15 - 서유럽(유로 기호와 프랑스어 및 핀란드 문자 추가)
UTF-8 - ASCII 호환 멀티바이트 8비트 유니코드
cp866 - DOS 전용 키릴 문자 집합
cp1251 - Windows 전용 키릴 문자 집합
cp1252 - Windows 전용 서유럽 문자 집합
KOI8- R - 러시아어
GB2312 - 중국어 간체, 국가 표준 문자 집합
BIG5 - 중국어 번체
---------------------- ---- --------------------------------- ---- -----



8: 함수 외부의 변수값을 함수 안에서 가져오는 방법


PHP 코드:--- ------ ------------------ ------ --------

[php]
$a="PHP";
foo ();
Function foo()
{
global $a;//여기를 삭제하고 결과를 확인하세요
Echo "$a";
}
[/php ]

------------------------------ ------- --------



9: 시스템이 기본적으로 지원하는지 어떻게 알 수 있나요?


PHP 코드:------- ------------ ------------ ----------------------

[php]
$arr = get_define_functions();
함수 php() {
}
echo "
";<br>Echo "여기에는 시스템에서 지원하는 모든 기능과 사용자 정의 기능 phpn이 표시됩니다.";<br>print_r($arr);<br>echo "
";
[/php]
-- ------------------------------------------------ -- -------------------


10: 둘의 차이점을 비교하는 방법 날짜


PHP 코드:------------------------- -------- ----------------------------- --------

[php]
$Date_1="2003-7-15";//다음과 같을 수도 있습니다: $Date_1="2003-6-25 23:29 :14";
$Date_2="1982-10-1";
$Date_List_1=폭발("-",$Date_1);
$Date_List_2=폭발("-",$Date_2);
$d1=mktime(0,0,0,$Date_List_1[1 ],$Date_List_1[2],$Date_List_1[0]);
$d2=mktime(0,0,0,$Date_List_2[ 1],$Date_List_2[2],$Date_List_2[0]);
$Days=round(($d1-$d2)/3600/24);
Echo "$Days일 동안 고생했어요^ _^";
[/php]

( strtotime($Date_1) - strtotime($Date_2))/3600/24
------------ ------- ----------------- -------


11: PHP를 업그레이드한 후 원래 프로그램이 전체 화면을 표시한 이유는 무엇입니까? 주의 사항: 정의되지 않은 변수:


변수가 정의되지 않아 발생하는 경고입니다.
php.ini를 열고 하단에서 error_reporting을 찾아 error_reporting = E_ALL & ~E_NOTICE

로 변경하세요. 구문 분석 오류 오류
error_reporting(0)을 닫을 수 없습니다.
오류 메시지를 닫으려면 php.ini를 열고 display_errors를 찾아 display_errors = Off로 설정하세요.

그럼 error_reporting은 뭔가요?



12: 각 파일의 시작과 끝 부분에 파일을 추가하고 싶은데 하나씩 추가하는 게 번거롭네요

1: php.ini 파일을 열고
include_path= "c:"

2:
auto_prepend_file.php 및 auto_append_file.php 두 파일을 작성하고 C 드라이브에 저장합니다. . 각 PHP 파일의 헤드와 테일에 자동으로 첨부됩니다.

3: php.ini에서 찾기:
PHP 문서 앞이나 뒤에 자동으로 파일을 추가합니다. 🎜>
PHP 코드:------------ ------ ---------------

[php]
Include "auto_prepend_file.php" ;

.....//여기에 프로그램이 있습니다


Include "auto_append_file.php";
[/php]

---------------------------- --- ---------------------------------------




13: PHP를 사용하여 파일을 업로드하는 방법



PHP 코드:--------- -- ------------------------------------------------ -- -------
[php]


파일 양식 업로드


파일을 선택하세요:






< /html>

$upload_file=$_FILES['upload_file']['tmp_name'];
$upload_file_name=$_FILES['upload_file']['name'];

if($upload_file){
$file_size_max = 1000*1000;//1M 제한 파일 업로드 최대 용량(바이트)
$store_dir = "d:/";// 업로드된 파일 저장 위치
$ accept_overwrite = 1;//동일 파일 덮어쓰기 허용 여부
//파일 크기 확인
if ($upload_file_size > $file_size_max) {
echo "죄송합니다. 파일 용량이 지정된 용량보다 큽니다.";
exit;
}

// 읽기 및 쓰기 파일 확인
if (file_exists($store_dir . $upload_file_name) && !$accept_overwrite) {
Echo "동일한 파일 파일 이름 존재 ";
exit;
}

//지정된 디렉터리에 파일을 복사합니다
if (!move_uploaded_file($upload_file,$store_dir.$upload_file_name)) {
echo "파일 복사 실패";
exit;
}

}

Echo "

파일을 업로드했습니다:";
echo $_FILES[ 'upload_file'][ 'name'];
echo "
";
//클라이언트 머신 파일의 원래 이름입니다.

Echo "파일의 MIME 유형:";
echo $_FILES['upload_file']['type'];
//브라우저에 필요한 파일의 MIME 유형 "image/gif"와 같은 지원되는 정보를 제공합니다.
echo "
";

Echo "업로드 파일 크기:";
echo $_FILES['upload_file']['size'];
//업로드된 파일 크기(바이트)입니다.
echo "
";

Echo "파일이 임시로 저장됩니다:";
echo $_FILES['upload_file']['tmp_name'];
//파일 업로드 후 서버에 저장되는 임시 파일 이름입니다.
echo "
";


$Erroe=$_FILES['upload_file']['error'];
switch($Erroe){
사례 0 :
Echo "업로드 성공"; break;
사례 1:
Echo "업로드된 파일이 php.ini의 upload_max_filesize 옵션에 의해 제한되는 값을 초과했습니다.";
사례 2:
            Echo    "上传文件的大小超过了HTML 表单中MAX_FILE_SIZE 选项指定的值。";    break;
        사례 3:
            Echo    "文件只有分被上传";break;
        사례 4:
Echo "파일이 업로드되지 않았습니다."
}
[/php]

-------- ------------------------------------- ------ ------------------ ------ --------



14: GD 라이브러리 구성 방법


다음은 저의 구성 과정입니다
1: dos 명령을 사용합니다(수동으로 수행할 수도 있습니다. dlls 폴더의 모든 dll 파일을 system32 디렉터리에 복사하세요) c:phpdlls*.dll c:windowssystem32
2: php.ini 열기
Extension_dir = "c:/php/extensions /";
3:
extension=php_gd2.dll; php_gd2.dll이 없는 경우에도 마찬가지입니다. php_gd.dll에 대해 이 파일이 있는지 확인하세요. c:/php/extensions/php_gd2 .dll
4: 테스트를 위해 다음 프로그램을 실행하세요

PHP 코드:--------- ----------- ------------- ------------------------ -

[php]
Ob_end_flush();
//정보가 없다는 점에 유의하세요. 그 전에 auto_prepend_file이 설정되어 있는지 주의하세요.
header ("Content- type: image/png");
$im = @imagecreate (200, 100)
또는 die("이미지를 생성할 수 없습니다.");
$Background_color = imagecolorallocate($im, 0,0, 0 );
$text_color = imagecolorallocate($im, 230, 140, 150);
imagestring ($im, 3, 30, 50, "간단한 텍스트 문자열", $text_color);
imagepng ( $im);
[/php]

------ -------------------------- ----------- --------------------------



결과를 보려면 여기를 클릭하세요



15: UBB 코드란 무엇입니까


UBB 코드는 HTML의 변형으로 Ultimate Bulletin Board입니다(외국 BBS 프로그램, 이 프로그램은 중국 여러 곳에서도 사용됩니다).
HTML 사용이 금지된 경우에도 UBBCode를 사용하여 구현할 수 있습니다. 그리고 포럼에서 HTML 사용을 허용하지 않는 경우에도 마찬가지입니다. 코드가 적게 필요하기 때문에 사용하는 것이 더 안전합니다.

Q3boy의 UBB에 예제가 있고, 직접 테스트를 실행할 수도 있습니다


16: MySQL 사용자 및 비밀번호를 수정한 것 같습니다

우선 대부분의 경우 MySQL을 수정하려면 mysql에서 루트 권한이 필요하므로
일반 사용자는 관리자에게 요청하지 않는 한 비밀번호를 변경할 수 없습니다.

방법 1
phpmyadmin을 사용하세요. 이것이 가장 간단합니다. mysql 라이브러리의 사용자 테이블을 수정하세요.
하지만 PASSWORD 기능을 사용하는 것을 잊지 마세요.

방법 2
mysqladmin을 사용하는 경우는 앞서 언급한 특별한 경우이다.
Mysqladmin -u root -p 비밀번호 mypasswd
이 명령을 입력한 후 원래 루트 비밀번호를 입력해야 하며, 그러면 루트 비밀번호가 mypasswd로 변경됩니다.
명령에서 루트를 사용자 이름으로 변경하면 비밀번호를 직접 변경할 수 있습니다.
물론 mysqladmin이 mysql 서버에 연결할 수 없거나 mysqladmin을 실행할 수 없다면
이 방법은 유효하지 않습니다.
그리고 mysqladmin은 비밀번호를 지울 수 없습니다.

다음 방법은 mysql 프롬프트에서 사용되며 mysql에 대한 루트 권한이 있어야 합니다.
방법 3
mysql> INSERT INTO mysql.user(Host,User,Password)
VALUES( '%','jeffrey',PASSWORD('biscuit'));
mysql> FLUSH PRIVILEGES
정확하게 말하면 사용자 이름이 jeffrey이고 비밀번호가 biscuit인 사용자를 추가하는 것입니다.
"mysql 중국어 참조 매뉴얼"에 이런 예시가 있어서 적어봤습니다.
PASSWORD 기능을 주의 깊게 사용하신 후 FLUSH PRIVILEGES를 사용하세요.

방법 4
REPLACE 문을 사용하는 것을 제외하면 방법 3과 동일합니다.
mysql> REPLACE INTO mysql.user (Host, User, Password)
VALUES('%',' jeffrey ',PASSWORD('biscuit'));
mysql> FLUSH PRIVILEGES

방법 5
SET PASSWORD 문 사용,
mysql> SET PASSWORD FOR jeffrey@"%" = PASSWORD('biscuit');
PASSWORD() 함수
도 사용해야 하지만 FLUSH PRIVILEGES를 사용할 필요는 없습니다.

방법 6
GRANT... IDENTIFIED BY 문
mysql> GRANT USAGE ON *.* TO jeffrey@"%" IDENTIFIED BY 'biscuit';
여기에 비밀번호( ) 기능이 필요하지 않으며 FLUSH PRIVILEGES를 사용할 필요가 없습니다.

참고: PASSWORD()는 Unix 비밀번호 암호화와 동일한 방식으로 비밀번호 암호화를 수행하지 않습니다.


17: 그가



PHP 코드를 통해 이 페이지에 어떤 웹사이트에 연결했는지 알고 싶습니다:------------ ------------------------------------- -----

[php]
//슈퍼 연결을 통해 입력해야 출력이 가능합니다
Echo $_SERVER[' HTTP_REFERER' ];
[/php]

----------------------------------- - ------------------------------------------------



18: 데이터를 데이터베이스에 넣을 때 주의할 점과 페이지에 표시하기 위해 꺼낼 때 주의할 점

데이터베이스에 들어갈 때
$str= addlashes($str);
$sql="`tab`(`content`) 값에 삽입('$str')";
라이브러리를 나갈 때
$str=stripslashes($str) ;
표시할 때
$str=htmlspecialchars( nl2br($str)) ;



addslashes() 함수는 지정된 사전 정의 문자 앞에 백슬래시를 추가합니다.

사전 정의된 문자는 다음과 같습니다.

작은따옴표(')
큰따옴표(")
백슬래시()
NULL

스트립슬래시() 함수 addlashes() 함수에 의해 추가된 백슬래시를 제거합니다.
htmlspecialchars() 함수는 미리 정의된 일부 문자를 HTML 엔터티로 변환합니다

19: 현재 주소 표시줄 정보를 읽는 방법



PHP 코드:---------------------------- ---- --------------------------------------

[php ]
$s="http://{$_SERVER['HTTP_HOST']}:{$_SERVER["SERVER_PORT"]}{$_SERVER['SCRIPT_NAME']}";
$se='' ;
foreach ($_GET as $key => $value) {
$se.=$key."=".$value."&"
}
$se=Preg_Replace ("/( .*)&$/","$1",$se);
$se?$se="?".$se:"";
echo $s."?$se ";
[/php]
----------------------------- ---------------




20: 뒤로가기 버튼을 눌렀는데 아까 작성했던 내용이 왜 사라졌나요?

세션을 사용했기 때문입니다.
해결책:

PHP 코드 :- ------------------------------------------------ -- -------------

[php]
session_cache_limiter('private, must-revalidate' ) ;
session_start();
.....
.....
[/php]

- ------------ ------------------------- ------------ --------------



21: 사진에 IP 주소를 표시하는 방법


PHP 코드:--- ------------------------- ------------ -----------------

[php ]
헤더("콘텐츠 유형: 이미지 /png");
$img = ImageCreate(180,50);
$ip = $_SERVER['REMOTE_ADDR'];
ImageColorTransparent($ img,$bgcolor);
$bgColor = ImageColorAllocate($img, 0x2c,0x6D,0xAF); // 배경색
$shadow = ImageColorAllocate($img, 250,0,0); // 그림자 색상
$textColor = ImageColorAllocate($img, oxff ,oxff,oxff); // 글꼴 색상
ImageTTFText($img,10,0,78,30,$shadow,"d:/windows/fonts/Tahoma .ttf",$ip);
ImageTTFText($img,10,0,25,28,$textColor,"d:/windows/fonts/Tahoma.ttf","귀하의 IP는". $ip) // IP 표시
ImagePng ($img);
imagecreatefrompng($img);
ImageDestroy($img);
[/php]

-- ------------ ------------------------- ------------ ---



22: 사용자의 실제 IP를 얻는 방법


PHP 코드:- -------------------------- ----------- ----------------

[php]
function iptype1 () {
if (getenv("HTTP_CLIENT_IP")) {
return getenv("HTTP_CLIENT_IP");
}
else {
return "none";
}
}
function iptype2 () {
if (getenv("HTTP_X_FORWARDED_FOR")) {
return getenv("HTTP_X_FORWARDED_FOR");
}
else {
return "none";
}
}
function iptype3 () {
if (getenv("REMOTE_ADDR")) {
return getenv("REMOTE_ADDR");
}
else {
return "none" ;
}
}
함수 ip() {
$ip1 = iptype1();
$ip2 = iptype2();
$ip3 = iptype3();
if (isset($ip1) && $ip1 != "없음" && $ip1 != "알 수 없음") {
return $ip1;
}
elseif (isset($ip2) && $ip2 ! = "없음" && $ip2 != "알 수 없음") {
return $ip2;
}
elseif (isset($ip3) && $ip3 != "없음" && $ip3 != "알 수 없음 ") {
return $ip3;
}
else {
return "none";
}
}

Echo ip();
[ /php]
------------------------------- ------ ----------



23: 데이터베이스에서 3일 이내의 모든 기록을 읽는 방법

먼저, 시간을 기록하려면 테이블에 DATETIME 필드가 있어야 하며
는 '2003-7 형식으로 -15 16:50:00'

SELECT * FROM `xltxlm` WHERE TO_DAYS(NOW()) - TO_DAYS(`date`) <= 3;


24: Mysql 데이터베이스에 원격으로 접속하는 방법


mysql 테이블에 사용자 추가를 위한 호스트 필드가 있는데, 이를 "%"로 변경하거나, 접속을 허용하는 IP 주소를 지정하여 원격 통화를 해보세요.

$link=mysql_connect("192.168.1.80:3306","root","");


25: 정규식 사용 방법

클릭 여기
정규 표현식의 특수문자


26: Apache 사용 후 홈페이지가 깨져서 나타납니다.


방법 1:
AddDefaultCharset ISO-8859-1 변경 AddDefaultCharset 해제 방법 2

:
AddDefaultCharset GB2312
============================== ==========================
팁:
코드를 게시하면 GB2312는????로 해석됩니다. ?

이렇게 변경하면 발생하지 않습니다
GB2312

10: 두 날짜 사이의 일수를 비교하는 방법, (간단한 알고리즘)


PHP 코드: ------------------------------- ------ --------

[php]
$Date_1="2003-7-15";//다음과 같을 수도 있습니다: $Date_1="2003-7-15 23:29:14";
$Date_2="1982-10-1";
$d1=strtotime($Date_1) ;
$d2=strtotime($Date_2);
$Days=round(($d1-$d2)/3600/24);
에코 " $Days일 동안 고생했어요^_^" ;
[/php]

------------------------- ---------- -------------- -------
round(123.456 ,2) = 123.46
ROUND ( 숫자 표현식 , 길이 )

round(123.456, -2) =100

길이가 양수인 경우, 숫자 표현은 길이 자릿수로 지정된 소수점으로 반올림됩니다. 길이가 음수이면 숫자 표현식은 길이로 지정된 소수점 왼쪽으로 반올림됩니다.

FLOOR(123.45), FLOOR(-123.45), FLOOR($123.45)

-- - ------                                                                                                              > 23.45), CEILING(-123.45), CEILING(0.0)

결과 집합은 다음과 같습니다.

------- -- - --------- - -- --- 

124                                                                                                                          ============ ========================================

27: 왜 할까요? 수락 페이지에서 작은따옴표와 큰따옴표('")가 표시됩니까?


해결 방법:
방법 1: php.ini에서 설정: Magic_quotes_gpc = Off
방법 2: $str= Stripcslashes($str)


28: 프로그램을 30초 후에 중지하지 않고 계속 실행하는 방법


set_time_limit(60)//최대 실행 시간은 1분입니다.
set_time_limit(0)//프로그램이 저절로 끝날 때까지 실행하거나 수동으로 중지


29: 현재 온라인에 있는 사람 수 계산

예 1: 텍스트를 사용하여

PHP 코드 구현:--------- ------- -----------------

[ php]
//우선 파일을 읽고 쓸 수 있는 권한이 있어야 합니다
//이 프로그램은 처음에 오류가 보고되면 나중에 실행할 수 있습니다
$online_log = "count.dat" ; //인원수 파일 저장,
$timeout = 30; //30초 이내에 아무런 조치도 취하지 않으면 오프라인으로 간주됩니다.
$entries = file($online_log );

$temp = 배열 ​​();

for ($i=0;$i$entry = 폭발(",",trim($entries[$i]));
if (($entry[0] != getenv('REMOTE_ADDR')) && ($entry[1] > time ())) {
array_push($temp,$entry[0].",".$entry[1]."n") //다른 뷰어의 정보를 가져와서 시간 초과된 항목을 제거하고 저장합니다. $temp
}
}

array_push($temp,getenv('REMOTE_ADDR').",".(time() + ($timeout))."n"); // 방문자 시간 업데이트
$users_online = count($temp); //온라인 사용자 수 계산

$entries = implode("",$temp);
//쓰기 file
$fp = fopen($online_log,"w");
Flock($fp,LOCK_EX); //flock()은 NFS 및 기타 네트워크 파일 시스템에서 제대로 작동하지 않습니다.
fputs($ fp ,$entries);
군중($fp,LOCK_UN);
fclose($fp);

echo "현재 있습니다".$users_online."사람들이 온라인 상태입니다";

[/php]
----------------------------------------- ------ -----------

예 2:
데이터베이스를 사용하여 온라인 사용자 구현


30: 템플릿이란 무엇이며 사용 방법


템플릿에 대한 몇 가지 기사는 다음과 같습니다

저는 phplib 템플릿을 사용합니다
다음은 여러 함수의 용도입니다

$T->Set_File("Any 정의", "Template file.tpl");

$T->Set_Block ("set_file에 정의됨", "", "원하는 대로 정의");

$T->Parse("정의됨 in Set_Block", "",true);

$T->Parse("원하는 대로 결과를 출력합니다.", "Set_File에 정의됨");

루프 형식을 다음과 같이 설정합니다:



방법 템플릿에서 정적 웹 페이지 생성

PHP 코드:--------------------------------- ------------- -----------

[php]
/ /여기서 phplib 템플릿 사용
............
............
$tpl->parse("output"," html");
$output = $tpl->get("output");// $output은 전체 웹페이지 콘텐츠입니다


함수 wfile($file,$content,$mode ='w') {
$oldmask = umask(0);
$fp = fopen($file, $mode);
if (!$fp) return false;
fwrite($ fp,$content);
fclose($fp);
umask($oldmask);
return true;
}
// 파일에 쓰기
Wfile($FILE ,$output);
header("location:$FILE");//생성된 웹페이지로 리디렉션
}
[/php ]
------------ ----------------------- -------------- -------



phplib 다운로드 주소 smarty 다운로드 주소


31: PHP를 사용하여

문자를 해석하는 방법 예: 2+2*(1+2)를 입력하면 자동으로 8
이 출력됩니다. 평가 함수 사용

PHP 코드:--------- ---------------- -------- ----------




[php]
$str=$_POST['str'];
eval ("$o=$str;");
Echo "$o";
[/php]

---------------------------------- --------- -------------


또한, 이 기능을 사용할 때 특히 주의하세요!!
누군가 d:? 형식을 입력하면 결과는 어떻게 될까요?
관련 라벨:
원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿