Skip to main content

PHP 에러, Cannot execute queries while other unbuffered queries are active.

PHP-PDO, mySQL에 대한 이야기 입니다. -ㅅ-)

프로젝트를 다른서버로 이전 작업도중에 다음과 같은 오류를 겪게 되었습니다.

PDOException: SQLSTATE[HY000]: General error: 2014 Cannot execute queries while other unbuffered queries are active. Consider using PDOStatement::fetchAll(). Alternatively, if your code is only ever going to run against mysql, you may enable query buffering by setting the PDO::MYSQL_ATTR_USE_BUFFERED_QUERY attribute.

열심히 구글링 해본결과 … 특별히 해결법을 찾을수가 없었네요…

다만 반복적인 쿼리를 2번이상할 때, 발생하는 것으로 확인했습니다.

전 서버에서는 무리 없이 잘되었는데…. (핑게 핑게..ㅋㅋ )

개발할 때 ORM에서 쿼리를 블럭 단위로 사용하게 되는데 insert하기전에 타임존을 설정하는 쿼리가 반복되어 생기는 문제였습니다. -_-;

SET time_zone='GMT';
  INSERT INTO
    `tr_clas_attend`
  (`cls_idx`, ~ 생략 ~ 

뿐만 아니라 set names utf8; 도 마찬가지더군요….

쿼리 시작시 한번만 적용하도록 수정하여 잘 해결되었습니다.

환경이 바뀌면 시스템이 잘못되었다고 생각할 때가 있는데, 하나하나 되집어보는 습관을 들여야 할 거 같네요…

무엇보다 개발할때, 전체를 생각하면서 개발해야하는데, 부분적인 것만 보고 개발해서 그랬던거 같습니다. -ㅅ-)

해결 과정중에 PDO::MYSQL_ATTR_USE_BUFFERED_QUERY 요놈을 PDO 인스턴스의 어트리뷰트로 설정했는데 일단 한글이 작동하지 않았고, 여러가지 문제가많이 생기더군요…

삽질기 끝….

PHAR :: PHP를 JAVA의 JAR 처럼 써보자

JAVA에서 여러 파일을 하나의 파일로 만들어주는 JAR가 있습니다.

JAVA에서는 jar파일 하나만으로 javaw -jar 어쩌구.jar 하면 프로그램이 실행됩니다. ^^;;

PHP에서 사이트를 배포할 때 하나의 파일로 배포한다면 더 빨리 배포할 수 있고,
라이브러리 배포 및 유지관리 측면에서도 유리한 점이 많을 것이라 생각됩니다.
(물론 압축을 풀어보면 알수있지만;; 아무나 파일을 못만지게 할수도 있고;;)

그래서 이번에는 PHP를 하나의 파일로 패키징(?) 할수 있는 PHAR을 알아봅시다.

PHP에 대한 환경설정이 필요합니다.

php.ini 파일에서 다음 부분을 On에서 Off로 수정합니다.

phar.readonly = Off

수정 후에는 웹서버를 재시작 해주세요 -ㅅ-)

폴더 구조를 한번 살펴봅시다.
PHP를 이용해서 빌드(?) 환경을 만든다고 생각하시는게 이해 하시기 빠를 것 같습니다.
src 폴더에 빌드할 PHP파일들을 넣어둡니다. 결과물은 build에 떨어집니다.
build 폴더의 권한은 PHP가 쓰기 작업을 할 수 있도록 707로 만들어둡니다.
phar_folder

그…리..고…..

src 폴더에 예제로 사용할 파일들을 만듭니다.
이건 예제일 뿐이고 -_- 실제로 사용하실 파일들은 잘 준비해보세요..
common.php

<?php
class MyApp
{
	public function run($name) {
		echo "Welcome 안녕하세요 헬로우,";
		echo $name;
	}

}

파일을 인클루드 하는 부분을 자세히 보세욥.. 이렇게 phar 파일 속에 있는 파일을 개별로 지정 할 수 있습니다.
index.php

run("주선주선");

이젠 프로그램도 준비가 되었겠다… 빌드하는 스크립트를 만들어 봅시다.
한방에 되면 좋겠지만…. 한방에 안됩니다.
빌드 스크립트의 위치는 앞에서 보여드린 phar폴더에 위치 시켜주세요. (아니면 경로를 상대적으로 잡으시면 원하시는 위치에도..)
build.php

<?php

$srcRoot = "./src";
$buildRoot = "./build";
 
$phar = new Phar($buildRoot . "/myapp.phar", 
 FilesystemIterator::CURRENT_AS_FILEINFO | FilesystemIterator::KEY_AS_FILENAME, "myapp.phar");
$phar["index.php"] = file_get_contents($srcRoot . "/index.php");
$phar["common.php"] = file_get_contents($srcRoot . "/common.php");
$phar->setStub($phar->createDefaultStub("index.php"));

php 사이트에서 보고 온거라 뭐라고 말은 못하겠지만 -ㅅ-) ㅋㅋ 소스 파일을 가져다가 압축하는 프로세스 인것 같스빈다.
추가할 파일을 하나하나 잘 넣어줘야합니다. 파일에 경로가 포함되어있으면 경로까지도 ….

이제 빌드를 해봅시다. 콘솔에서 사용하셔도 되고 브라우저에서 하셔도 됩니다. (저는 콘솔에서)

$ php build.php 

그러면, build 폴더에 myapp.phar이 생성됩니다.

myapp.phar 파일을 실제로 구동해봅시다.

<?php
require "./build/myapp.phar";

(음.. 이게 답니다. -_- )

phar_run

여기까지 입니다.

즐거운 개발 되시길 ….

윈도우 mongoose에 php7 사용해보기

정말 간단하게 윈도우 로컬에서 PHP로 해야할 작업이 있어서 찾아보았습니다.

usbwebserver를 쓸려고 했는데 크기가 더 작은 녀석이 있네요…

mongoose 웹서버 입니다.

물론 .. 나름 구동방식에 있어서 장단점은 있지만 로컬에서 혼자 개발하는 용도로는 최적인 것 같습니다.

다운로드 링크는 다음주소에 있습니다.

https://code.google.com/archive/p/mongoose/

5.0이 최신이긴하지만… php가 잘 작동하지 않습니다.

mongoose_download

4.1 버전을 다운로드 합니다. 물론 이 속에 들어있는 PHP 버전은 5.x 입니다.

압축을 풀어보면 다음과 같은 파일이 있습니다. web_root 에 php프로그램을 저장합니다.
moongoose_files
mongoose.exe를 실행하면 윈도우 트레이에 아이콘이 뜨고 localhost:8080으로 브라우저로 접속해 볼수 있습니다.
그대로 써도 상관은 없지만 php의 extension이 다 빠진 상태라 난감합니다. ㅋㅋ -ㅅ-) sqlite3 정도 되는 수준….

이제 mongoose를 쓸만하게 만들어 볼겁니다.

1. http://www.php.net에가서 php7 윈도우 버전 바이너리를 받아옵니다. 받아온 파일은 mongoose하위폴더에 php7으로 위치 시킵니다.
php5ts.dll과 php-cgi.exe는 php5 버전임으로 삭제 합니다.
대략 폴더/파일이 다음과 같은 모양이 됩니다.
mongoose_files2

2. mongoose.conf 파일을 편집합니다. (html도 추가해주고 php-cgi.exe 경로도 넣어주고 …. )
내장된 설정창에서도 변경이 가능하지만 절대경로로 들어가버려서 폴더 위치를 옴기면 설정이 변경되어 버립니다.
(다음과 같이 상대경로로 잡아두면 cd, usb등에 넣어다닐때 편리합니다.)

cgi_pattern **.cgi$|**.pl$|**.php$|**.html$
cgi_interpreter php7/php-cgi.exe
listening_ports 8080,8081s
document_root web_root
ssl_certificate ssl_cert.pem
url_rewrite_patterns /xy=web_root\index.php

3. php.ini 파일을 생성합니다. 물론 mongoose 폴더에 같이 둡니다. 간단하게 필요한 extenstion 들만 추가해서 간단하게 만듭니다.
이것저것 필요한 설정들을 넣어주도록 합니다. 이 내용은 php7 폴더에 있는 php.ini-dest 등을 참고해주세요.

date.timezone = "Asia/Seoul"

extension_dir = "./ext"
extension=php_gd2.dll

그러면 최종적으로 파일들은 이렇게 됩니다.
mongoose_files3

4. 해도되고 안해도 되는 php파일정리
이렇게 해주면 용량이 매우 줄어듭니다. -ㅅ-)
mongoose_files4

mongoose-php7

이렇게 해서 외장하드에서 관리하는 포토겔러리를 만들었습니다.
자세한 소스는 다음에 ….. -ㅁ-)
아직 정리가 되지 않음….

PHP에서 한글 정규식사용하기

PHP에서 한글 정규식을 사용해봅시다.

원래는 2바이트 특수문자 차단을 위해서 시작하였으나 -_-; 특수문자의 유니코드 범위가 들숙날쑥이라 범위를
지정할 수가 없었습니다. ㄷㄷㄷ

$pattern = '/[#&*@§※☆★○●◎◇◆□■△▲▽▼→←↑↓↔〓◁◀▷▶♤♠♡♥♧♣⊙◈▣◐◑▒▤▥▨▧▦▩♨☏☎☜☞¶†‡↕]/u';

삽질의 흔적….
이렇게하면 한도 끝도 없이 모든걸 다 정규식에 넣어줘야 하는 상황이 발생하니 정규식은 의미가 없게 되겠죠…

…. 삽질 중략 …..

특수문자를 검출 할 수 없다면, 한글,영문, 키보드의 기본문자 등을 검출하여 남는 녀석이 2바이트 특수문자가 되겠구나 라는 아이디어를 이베이프(evape.kr)님께서 아이디어를 주셨습니다. ㅎㅎ (역시 개발자이심)

그리고 열심히 구글을 검색하던 도중 정규식에서도 \x{코드}를 통해서 유니코드를 사용할 수 있다는 것을 알았습니다. ㅋㅋ

무조건 만드는게 아니라 이해를 하고 만들어야해서 다음 페이지에서 많은 도움을 받았습니다. -ㅅ-) 감사..
http://d2.naver.com/helloworld/76650
(한글 코드 범위에 대해서 많은 참조가되었습니다. ^^)

요즘은 정리가 잘되어있어서 찾아도 잘 나오니….

아무튼.. 다음과 같은 결론에 도달하였습니다.

<?
$pattern = '/[\x{1100}-\x{11FF}\x{3130}-\x{318F}\x{AC00}-\x{D7AF}a-zA-Z0-9~`!@#$%^&*()+\-.:;,_<>?\[\]\{\}\/"\' ]+/u';
$tmp_subject = preg_replace($pattern, "", $subject,-1);
echo $tmp_subject;
?>

$tmp_subject에 걸러지는 녀석이 있으면 2바이트 특문이 되게 됩니다.

테스트 URL : http://jusun.org/example/preg/preg2.php

테스트는 해보지 않았지만 아마 JavaScript에서도 별탈없이 잘 돌아갈것같네요..

오늘도 여기까지…. -ㅅ-)