Hôm rồi mình có viết một công cụ bằng PHP làm số 1 việc. Trong đó người dùng sẽ phải truyền tham biến (parameter) là một tên miền (domain) hợp lệ vào URL. Tuy nhiên thay vì nhập 1 tên miền hợp lệ thì nhiều người dùng chạy lệnh để khai thác lỗi SQL Injection.
data:image/s3,"s3://crabby-images/7a633/7a63324de14deb889d67f1b300a4b9f2c26c131a" alt=""
Vậy là phải viết hàm để kiểm tra tham biến truyền vào có phải đúng định dạng của 1 tên miền hợp lệ hay không. Nếu đúng thì mới cho chạy tiếp không thì chặn ngay và luôn. Và đây là hàm mình sử dụng:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 | function checkValidDomain($domain_name){ //FILTER_VALIDATE_URL checks length but..why not? so we dont move forward with more expensive operations $domain_len = strlen($domain_name); if ($domain_len < 3 || $domain_len > 253) return FALSE; //getting rid of HTTP/S just in case was passed. if(stripos($domain_name, 'http://') === 0) $domain_name = substr($domain_name, 7); elseif(stripos($domain_name, 'https://') === 0) $domain_name = substr($domain_name, 8); //we dont need the www either if(stripos($domain_name, 'www.') === 0) $domain_name = substr($domain_name, 4); //Checking for a '.' at least, not in the beginning nor end, since http://.abcd. is reported valid if(strpos($domain_name, '.') === FALSE || $domain_name[strlen($domain_name)-1]=='.' || $domain_name[0]=='.') return FALSE; //now we use the FILTER_VALIDATE_URL, concatenating http so we can use it, and return BOOL return (filter_var ('http://' . $domain_name, FILTER_VALIDATE_URL)===FALSE)? FALSE:TRUE; } |
Hàm sẽ trả về giá trị TRUE hoặc FALSE.
Xin chia sẻ để các bạn có thể tham khảo khi cần.
Huỳnh Mai Anh Kiệt
- Advertisement -