Powered By Blogger

08 October 2014

Test Using Doctrine in Windows 7 , Install by composer


run install Doctrine ORM

create file composer.json
{
    "require": {
        "doctrine/orm": "*" ,
"symfony/yaml": "2.*"
    }
}

download file composer.phar  from WebSite Composer
https://getcomposer.org/
https://getcomposer.org/download/
I load by ...
php -r "readfile('https://getcomposer.org/installer');" | php

Note: must enable mod_openssl  in c:\windows\php.ini or error  !
extension=php_openssl.dll

then from myfolder
C:\Appserv\www\test_doctrine3\> 
I run command 
>php composer.phar  install  

this will install Doctrine and some component from Symphony2  ( Must connect to Internet )

after install will have folder  vendor 
C:\Appserv\www\test_doctrine3\vendor  , this folder is all component that install by composer 

I will work in folder 
C:\Appserv\www\test_doctrine3
and 
run command like 
vendor\bin\doctrine orm:convert-mapping --from-database xml entities

Database Test with MySQL Server 5.x  at localhost  

==================================================================
NOTE
Main Official Tutorial Page
http://symfony.com/doc/current/book/doctrine.html
http://symfony.com/doc/current/cookbook/doctrine/reverse_engineering.html
http://symfony.com/doc/current/bundles/SensioGeneratorBundle/commands/generate_doctrine_entity.ht

REF ..
http://stackoverflow.com/questions/4844523/generating-mapping-information-on-existing-database-use-doctrine-2



Create XML from DB ( 4 Type of Entities , Equal )
vendor\bin\doctrine orm:convert-mapping --from-database xml entities
vendor\bin\doctrine orm:convert-mapping --from-database yml entities <--? (entities is subfolder )
vendor\bin\doctrine orm:convert-mapping --from-database php entities <--?  NOT USE THIS !!  , Cannot Read Code
vendor\bin\doctrine orm:convert-mapping --from-database annotation entities <-- This Create POJO Class !!!

Convert XML to YAML is
vendor\bin\doctrine orm:convert-mapping  ???


Create PHP Class from DB
vendor\bin\doctrine orm:generate-entities .

Gen DATABASE from Entities  ---- > YES , But Must Have Entities Class Too .
vendor\bin\doctrine orm:schema-tool:create

Show all commoand of orm
vendor\bin\doctrine  orm:a
vendor\bin\doctrine  orm:s
vendor\bin\doctrine  orm:?
vendor\bin\doctrine  orm:*


Show Help
vendor\bin\doctrine orm:info --help

C:\AppServ\www\test_doctrine>vendor\bin\doctrine  orm:schema-tool:create --dump-
sql
CREATE TABLE dojos (id INT AUTO_INCREMENT NOT NULL, name VARCHAR(255) NOT NULL,
PRIMARY KEY(id)) DEFAULT CHARACTER SET utf8 COLLATE utf8_unicode_ci ENGINE = Inn
oDB;
CREATE TABLE starters (id INT AUTO_INCREMENT NOT NULL, name VARCHAR(255) NOT NUL
L, dojo INT NOT NULL, PRIMARY KEY(id)) DEFAULT CHARACTER SET utf8 COLLATE utf8_unicode_ci ENGINE = InnoDB;


============================================================
Note: PATH Struture

Folder PATH listing for volume OS
Volume serial number is 00330065 50A2:952B
C:.
+---dojos
+---entities
+---entities_backup
\---vendor
    +---bin
    +---composer
    +---doctrine
    |   +---annotations
    +---cache
    |   +---dbal
    |   +---inflector
    |   +---lexer
    |   \---orm
    \---symfony
        +---console
        \---yaml
            \---Symfony

=============================================================
C:\AppServ\www\test_doctrine3>dir
 Volume in drive C is OS
 Volume Serial Number is 50A2-952B

 Directory of C:\AppServ\www\test_doctrine3

10/08/2014  03:37 PM    <DIR>          .
10/08/2014  03:37 PM    <DIR>          ..
10/08/2014  03:37 PM             7,362 a1.txt
10/08/2014  03:26 PM               641 bootstrap.php
10/07/2014  06:07 PM               431 cli-config.php
10/08/2014  03:08 PM                91 composer.json
10/08/2014  03:10 PM            22,878 composer.lock
10/07/2014  05:47 PM         1,029,188 composer.phar
10/08/2014  03:23 PM    <DIR>          dojos
10/08/2014  03:35 PM    <DIR>          entities
10/08/2014  02:50 PM    <DIR>          entities_backup
10/07/2014  06:25 PM               182 gen_xmlfrombase.bat
10/08/2014  03:39 PM             1,831 NOTE_ON_GENERATE.txt
10/08/2014  03:10 PM    <DIR>          vendor
               8 File(s)      1,062,604 bytes
               6 Dir(s)   bytes free

install XAMPP on CentOS/RedHat 6

install XAMPP on CentOS  6

URL 1
http://sharadchhetri.com/2014/03/24/install-xampp-centosrhel-6-5/

URL 2 
http://setup-steps.blogspot.com/2013/01/xampp-for-linux-on-centos-63.html

========================================================

====  Brief from URL 1 ====

yum install wget
wget http://downloads.sourceforge.net/project/xampp/XAMPP%20Linux/1.8.3/xampp-linux-x64-1.8.3-3-installer.run

chmod +x xampp-linux-x64-1.8.3-3-installer.run

./xampp-linux-x64-1.8.3-3-installer.run

vi /opt/lampp/etc/extra/httpd-xampp.conf
(add
=====
<LocationMatch "^/(?i:(?:xampp|security|licenses|phpmyadmin|webalizer|server-status|server-info))">
# Require local
Require all granted
ErrorDocument 403 /error/XAMPP_FORBIDDEN.html.var
</LocationMatch>
======
)

/opt/lampp/lampp restart

http://localhost/xampp

http://localhost/phpmyadmin

=================================================================

แต่ถ้าให้คิดจริงๆ วิธี ติดตั้ง ทีละตัว ง่ายกว่าเยอะ

http://www.techiecorner.com/125/how-to-install-lamp-apache-php-and-mysql-in-linux-using-yum/

yum install ไปทีละตัวเลย

หรือรัน setup บน konsole ก็ได้  

18 September 2014

การตั้ง FTP Server ใน Windows Server 2003 ( รุ่นเก่ามากๆแล้วนะ )

ข้อมูล ใน Microsoft Knownledge Base เลยนะครับ

ภาษาอังกฤษ น่ะ

http://support.microsoft.com/kb/323384/th


หลังจากนั้น การเข้าใช้ ให้ ล้อกอินด้วย  user ของ windows
โดยเข้าผ่าน ftp://[ IP Address]/   แล้วป้อน user /pass ของ windows
จะมีการ แสดง Listing แบบ Web Interface


แต่ถ้าต้องการ copy ไฟล์จำนวนมาก ควรใช้พวก FTP Client เช่น  FileZilla FTP Client
แล้ว เลือก Quick Connection ป้อน ชื่อ Host  (IP หรือ  Domain Name )
แล้ว โปรแกรมจะลิสต์ รายการของไฟล์มาให้  copy file ได้เร็วกว่ากันมากๆ

ตามปกติแล้ว  Protocol FTP จะเร็วกว่า File Sharing มากๆ

16 September 2014

Apache Web Server : การซ่อนไฟล์บางไฟล์จาก Web Folder ด้วย .htaccess


ป้องกัน ไม่ให้แสดง file *.php และ รูปภาพบางอย่าง 











จะแสดงทั้งข้อมูล ใน Folder ทั้งหมด ยกเว้น File นามสกุล .gif , .png และ .php 
ส่วนไฟล์อื่นๆเช่น  file .txt จะแสดงรายการไว้  

(แม้ไม่แสดงชื่อไฟล์แต่จะยังเข้าถึงไฟล์นี้ผ่าน url ได้อยู่ นะครับ )


ตัวอย่างเช่นสร้าง File ดังนี้  ใน Folder 













จะเห็น   ใน Browser ดังนี้



















นั่นคือ จะเห็นได้ว่า  Web Sever จะแสดงเฉพาะไฟล์ที่ไม่อยู่ในรายการ
โดย ไฟล์ .htaccess จะอยู่เพียง ใน Folder myinfo
แล้ว Folder  myinfo\folder1 จะ สืบทอดการตั้งค่าแสดงผลของ .htaccess มาด้วย

ดังนั้นทั้ง 2 folder จะเห็นเพียง file .txt เท่านั้นทั้งๆที่มีทั้ง ไฟล์ .txt และ .php

แต่นี่ไม่ใช่การป้องกันการเข้าถึงไฟล์ a1.php นะครับ  ยังสามารถเรียกใช้ได้ตามปกติ 
เพียงแค่ไม่ให้แสดงใน Index เท่านั้น 



11 August 2012

start Apache Tomcat แบบง่ายๆ

หนังสือหลายๆเล่ม สอนมากมายเกี่ยวกับวิธี
ถูกบ้างผิดบ้าง แล้วก็รันไม่ได้ บ้าง


มาลองดูวิธีง่ายๆกัน กับ Tomcat5.5 ที่ผมค้นพบ
วิธีนี้สำหรับ  Windows ครับ
แล้ววิธีนี้ก็ใช้ในกรณีที่เราไม่ได้ ติดตั้ง Tomcat  เป็น Service
เพียงแค่ Download Tomcat มาแล้วแตกไฟล์ไว้ที่เครื่องของเราเอง

ตัิวอย่างประมาณนี้ครับ


D:\tomcat55\bin>set JAVA_HOME=c:\Program Files\Java\jdk1.7.0_03

D:\tomcat55\bin>version.bat
Using CATALINA_BASE:   D:\tomcat55
Using CATALINA_HOME:   D:\tomcat55
Using CATALINA_TMPDIR: D:\tomcat55\temp
Using JRE_HOME:        c:\Program Files\Java\jdk1.7.0_03
Using CLASSPATH:       D:\tomcat55\bin\bootstrap.jar
Server version: Apache Tomcat/5.5.35
Server built:   Jan 6 2012 11:20:07
Server number:  5.5.35.0
OS Name:        Windows XP
OS Version:     5.1
Architecture:   x86
JVM Version:    1.7.0_03-b05
JVM Vendor:     Oracle Corporation
D:\tomcat55\bin>startup.bat
Using CATALINA_BASE:   D:\tomcat55
Using CATALINA_HOME:   D:\tomcat55
Using CATALINA_TMPDIR: D:\tomcat55\temp
Using JRE_HOME:        c:\Program Files\Java\jdk1.7.0_03
Using CLASSPATH:       D:\tomcat55\bin\bootstrap.jar
D:\tomcat55\bin>

สรุปง่ายๆคือ  set java_home ก่อน แล้วตามด้วย version.bat แล้วตามด้วย startup.bat  เป็นอันจบ
หลังจากนั้น ระบบจะเปิด หน้าจอ console สีดำๆึขึ้นมาใหม่อีกหน้าจอ รอรับ sequest
และทำหน้าที่เป็น server รอรับ HTTP Request ที่ port มาตรฐานของ Tomcat คือ  8080 ครับ
นั่นก็คือที่  http://localhost:8080/

  


ลบข้อมูลบรรทัดว่าง ด้วย autoIT

สร้างและ run script สำหรับ ลบ บรรทัดว่าง
เช่นข้อมูล บน notepad

A B C

D E F

G H I

๋๋J K L

จะมีบรรทัดว่างอยู่
ให้เปิด autoITv3 Editor ขึ้นมา พิมพ์ดังนี้


Send("!{TAB}") ; ALT-TAB
local $i
for $i = 1 to 3
   Send("{DEL}")
   Send("{DOWN}")
Next

แล้วสวิชกลับไปที่  notepad เอาเมาส์คลิกให้ cursor อยู่ที่่บรรทัดว่างใต้ตัว A เหนือตัว D
แล้ว กด ALT-TAB เพื่อสวิชกลับไปที่ autoIT
แล้วกด ปุ่ม F5

ซึ่งมันจะทำงานดังนี้ คือ
สวิชกลับไปที่  notepad
ลบบรรทัดว่าง ระหว่าง A กับ D  ผลคือ cursor อยู่ที่ D
จำลองการกดปุ่ม ลูกศรลง แล้วจะไปอยู่ที่ บรรทัดว่างระหว่าง  D กับ G

ลบบรรทัดว่าง ระหว่าง D กับ G  ผลคือ cursor อยู่ที่ G
จำลองการกดปุ่ม ลูกศรลง แล้วจะไปอยู่ที่ บรรทัดว่างระหว่าง  G กับ J

ลบบรรทัดว่าง ระหว่าง G กับ J  ผลคือ cursor อยู่ที่ J


ผลลัพธ์ คือ

A B C
D E F
G H I
๋๋J K L



===  ใช้งานด้วยความระมัดระวังนะครับ ===
===  การรันโปรแกรม ควบคุม keyboard/mouse แบบนี้  ===
===  อาจทำให้เครื่องคุณ โดนลบข้อมูล ไฟล์เสียหาย  ===
===  หรือหนักกว่านั้นได้เลย  เช่นต้อง Format เครื่องใหม่ === 


ดึงข้อมูล HTTP ด้วย ภาษา Scala และ Library Java

การ ดึงข้อมูล HTTP จากหน้าเว็บไซต์  เช่น port 80
ซึ่งก็อาจใช้ในการ ทดสอบโปรแกรมระบบ ได้เช่นกัน

ตัวอย่าง batch file สำหรับ set classpath
 Directory of D:\scala-2.9.2

08/11/2012  01:12 AM    <dir>          .
08/11/2012  01:12 AM    <dir>          ..
08/11/2012  01:12 AM    <dir>          bin
04/13/2012  05:25 AM    <dir>          doc
08/08/2012  12:02 AM    <dir>          lib
04/13/2012  05:25 AM    <dir>          man
04/13/2012  05:25 AM    <dir>          misc
08/11/2012  12:06 AM               152 setpath.bat
04/13/2012  05:25 AM    <dir>          src



ข้อมูล batch เป็นดังนี้
set path=%PATH%;c:\Program Files\Java\jdk1.7.0_03\bin;
set path=%PATH%;D:\scala-2.9.2\bin;
set JAVA_HOME=c:\Program Files\Java\jdk1.7.0_03\bin
Source Code get_http.scala
import java.net.URL
import java.net.HttpURLConnection
val url = new URL("http","localhost",80,"/apt")
val con = url.openConnection.asInstanceOf[HttpURLConnection]
con.setRequestProperty("Header","Value")
con.connect()
val ips = con.getInputStream()
for( i <- 1 to ips.available ){
   print( ips.read.asInstanceOf[Char] )
}

เป็นการแสดงตัวอย่าง Source Code ภาษา Scala ซึ่งเรียกใช้  object/method ของ java 
โดยสร้าง URL ระบุ protocol , host , port , path หรือ ไฟล์ 
แล้วเปิดคอนเนคชัน และ cast type เป็น  HttpURLConnection
ลองส่ง Property ไปเล่นๆ 
เปิด connection จริง 
ดึงข้อมูล ImputStream ใส่ตัวแปร pointer ips 
วนรอบเท่าจำนวนตัวอักษรที่อ่านได้ (ips.available)  
แล้ว อ่านทีละตัวอักษรซึ่งจะเป็นเลข interger แล้ว CastType ไปเป็น Char 
แล้ว พิมพ์ออกทางหน้าจอ  


ตัวอย่างผลลัพธ์ 
scala> :load get_http.scala
Loading get_http.scala...
import java.net.URL
import java.net.HttpURLConnection
url: java.net.URL = http://localhost:80/apt
con: java.net.HttpURLConnection = sun.net.www.protocol.http.HttpURLConnection:ht
tp://localhost:80/apt
ips: java.io.InputStream = sun.net.www.protocol.http.HttpURLConnection$HttpInput
Stream@3dd423
NO Screen Info !
redirect to $http://localhost/apt/index.php/unmanage/check_d
evice_res/
scala> 

จะเห็นว่ามีการดึงข้อมูลได้ ถูกต้อง แต่มีการแสดง Source Code ด้วยเพื่อ ตรวจสอบข้อผิดพลาด 
หากต้องการให้ไม่แสดง Source Code ให้ใช้คำสั่ง   :silent  แล้วโหลด code มารันด้วย :load 
ดังนี้ 
scala> :silent
Switched off result printing.

scala> :load get_http.scala
Loading get_http.scala...
NO Screen Info !
redirect to $http://localhost/apt/index.php/unmanage/check_d
evice_res/
scala>


อ้างอิงจาก 






10 March 2012

สร้าง user บน pure-ftpd (ubuntu )

ใน pure-ftpd จะมีคำสั่งสร้าง user
และระุบุให้ผูกกับ  user ของ OS
ดังนี้
http://support.real-time.com/open-source/pureftpd/index.html
โดยห้าม ใช้  uid OS  ซีึ่งเป็น "root" และ   "gid" เป็น root
ทำให้ต้องมีการ สร้าง user ของ OS ใหม่

การสร้าง user ใหม่ ใน ubuntu
ลองสร้างดูด้วย วิธีนี้

useradd  ซับซ้อนหน่อย ต้องระบุ path ให้ แล้วต้องมากำหนด password ด้วย  "passwd"  อีกครั้ง
adduser เหมือนมี text gui มาช่วยให้ป้อนค่าต่างๆง่ายมากๆ
http://www.howtogeek.com/howto/ubuntu/add-a-user-on-ubuntu-server/

หรือหากจะสร้าง ด้วย gui ก็ตามนี้ครับ
http://blog.it.kmitl.ac.th/it51070105/2008/07/10/%E0%B8%81%E0%B8%B2%E0%B8%A3%E0%B8%AA%E0%B8%A3%E0%B9%89%E0%B8%B2%E0%B8%87-user-%E0%B9%83%E0%B8%99-ubuntu/

สมมุติ สร้าง user ของ OS ชื่อ tu2 มาแล้ว

ขั้นตอนที่จะสร้าง user ของ  pure-ftpd ก็จะทำตามเอกสารนี้
http://download.pureftpd.org/pub/pure-ftpd/doc/README.Virtual-Users
แต่จะปรับเปลี่ยนเล็กน้อย คือ

ที่ path
root@root: /etc/pure-ftpd#
รันคำสั่งดังนี้
#groupaddd   ftpgroup
#useradd  -g ftpgroup  -d /home/ftpuser -s  /etc  ftpuser
#pure-pw  useradd   tu2  -u ftpuser  -d  /home/ftpuser/joe
ใส่พาสเวิร์ด สองครั้ง
เป็นการผูก  user:OS  tu2 เข้ากับ  user (อ่านรีบๆเดาว่าน่าจะเป็น) แบบ virtual user "ftpuser"
และกำหนดให้ path ของ directory เป็น /home/ftpuser/joe


แต่ว่าใส่ผิด ชื่อไม่ตรง คือใส่ joe ต้องการ ลบ user นี้ออกจาก ftp เพื่อจะเปลี่ยน folder ที่เก็บ
#pure-pw  userdel  tu2

#pure-pw  useradd   tu2  -u ftpuser  -d  /home/ftpuser/tu2
ใส่ password สองครั้ง


จะทำให้ สามารถ logon จาก  core FTP ( windows )
ได้ โดย ใช้ user tu2
ซึ่งเป็นการ เปิด จาก port 21

 ถ้าจะใ้ห้ ปลอดภัยขึ้นควร ใช้ SSH แทน ซึ่งเป็น port 22 จะปลอดภัย มีการเข้ารหัสข้อมูล
 ซึ่ง port 21 แบบ FTP นี้ ไม่มีการเข้ารหัสข้อมูลใดๆ ทั้งสิ้น

 แต่ในที่นี้ สอน การใช้งานแบบง่ายๆ ในหน่วยงาน หรือ สำหรับ Test Server
 หรือ ใช้ ภายใน VMware / VirtualBox เป็นหลัก ( ผมก็ ใช้เพื่อการนี้แหละ ... แบบ Host - Only ด้วย )

------------------------
ผลลัพธ์ หลังจากลองแบบ รีบด่วนแล้ว
พบว่า  login ftp ได้ที่  /home/tu2
ซึ่งก็พบว่า  ใช้ CoreFTP (windows )  โหลด ไฟล์จาก   Pure-ftpd (Ubuntu ) ได้
และยังสามารถ ส่งไฟล์จาก  CoreFTP (windows )  ไปยัง   Pure-ftpd (Ubuntu ) ได้ ด้วย
โดยจะส่งไปวางไว้ที่  /home/tu2

ซึ่งก็จะเป็นวิธีการ รับส่งไฟล์แบบง่ายๆ ในสภาพแวดล้อมที่  มีความเสี่ยงต่ำ
ระหว่าง  linux กับ  windows

... อืม ... อาจมีวิธีง่ายกว่านี้ แต่นึกไม่ออก น่ะ    :D

20 May 2011

การ Set Firewall สำหรับ WebServer บน CentOS

หาอ่าน เอกสารวิธี set iptables ได้จาก

http://www.cyberciti.biz/faq/howto-rhel-linux-open-port-using-iptables/

แต่ว่าลองใน VM แล้ว เครื่อง Host (Vista )
ก็ยังไม่สามารถมองเห็น web server ได้

อ่านดู ล่างๆ บอกว่าให้รัน
system-config-securitylevel  จาก  # 
หรืออาจไปใช้  #setup แล้วเลือก ส่วน Firewall 


ลองๆทำดู ลองเลือก Disable Firewall ก็เห็น Web จาก CentOS ได้ทันทีเลย
ลองปรับปรุงใหม่ ให้ Customize ให้เลือกเฉพาะ HTTP ,  TELNET , FTP  ก็น่าะพอ 
สำหรับงานทั่วๆไปทำเว็ป และ upload content , และจัดการกับ server ผ่าน console  


ผลคือ ใช้งานได้ครับ 
http://.... 
ftp://... 


----------------------------
ส่วนการ ติดตั้ง telnet นั้นอาจต้อง yum update ก่อน
แต่ว่า ต้อง ตั้งค่า DNS ก่อนนะครับ 


ใช้  #setup แล้วเลือก ส่วน Network แล้วไปแก้ไข ค่า DNS เพิ่ม Primary DNS , Secoundary DNS ถ้ามี
อันนี้ ใช้ GUI ได่้  แต่จะยัง ping google ไม่ได้ นะครับ 


แล้วต้อง  restart network ใหม่ก่อน ด้วยคำสั่ง
#service network restart  
รอสักครู่ แล้ว ลอง ping www.google.co.th  
หยุดด้วย Ctrl-C หรือ อาจ ping  -c 3 www.google.co.th ก่อน  


ข้อมูลจาก WEB --> http://www.arnut.com/b/CentOSUsing7 
-----------------------------
หลัง รัน   ping google ได้แล้ว ลอง update yum 
ด้วย 
#yum update 
แล้ว install  ดัวย 
#yum install  telnet-server
#yum install  telnet-server


#service telnet-server status  


ดูส่วนนี้ประกอบด้วย  --> http://huu2uan.posterous.com/install-telnet-server-on-centos-5