|
|
|
รบกวนดู scrip php upload & crop รูปภาพให้หน่อยครับ |
|
|
|
|
|
|
|
รบกวนผู้รู้ช่วยดู code หน่อย เป็น code อัปโหลดรูป เมื่อเราอัปโหลดเสร็จระบบให้เรา crop รูป ซึ่งสำหรับบนพีซีไม่มีปัญหา แต่เป็นปัญหาบนสมาร์ทโฟน ทำให้ไม่สามารถลาก crop รูปไม่ได้ "" รบกวนช่วยดูว่าต้องแก้ไขตรงไหน หรือไม่ก็แก้ให้ข้ามฟังก์ชั่น crop ได้ไหม""
Code (PHP)
<?php
error_reporting (E_ALL ^ E_NOTICE);
session_start(); //Do not remove this
require_once('config/config.ini.php');
require_once('config/function.php');
if(isset($_GET['seccode1']) && isset($_GET['seccode2'])){
$seccode1 = $_GET['seccode1'];
$seccode2 = $_GET['seccode2'];
$con = db_connect();
$sql = "SELECT id,pic FROM friend_list WHERE MD5(lineid)='".$seccode1."' AND MD5(dateadd)='".$seccode2."'";
$query = mysql_query($sql);
if(mysql_num_rows($query)){
$data = mysql_fetch_array($query);
$_SESSION['usrid'] = $data['id'];
$_SESSION['usrpic'] = $data['pic'];
}else{
$_SESSION['usrid'] = 0;
}
mysql_close($con);
}else{
if(!isset($_SESSION['usrid'])){
$_SESSION['usrid'] = 0;
}
}
if($_SESSION['usrid']){
$con = db_connect();
//only assign a new timestamp if the session variable is empty
if (!isset($_SESSION['random_key']) || strlen($_SESSION['random_key'])==0){
$_SESSION['random_key'] = strtotime(date('Y-m-d H:i:s'));
$upload_dir = "../upload_pic"; // The directory for the images to be saved in
$upload_path = $upload_dir."/"; // The path to where the image will be saved
$large_image_prefix = $_SESSION['usrid']."_resize"."_"; // The prefix name to large image
$thumb_image_prefix = $_SESSION['usrid']."_thumbnail"."_"; // The prefix name to the thumb image
$large_image_name = $large_image_prefix.$_SESSION['random_key']; // New name of the large image (append the timestamp to the filename)
$thumb_image_name = $thumb_image_prefix.$_SESSION['random_key']; // New name of the thumbnail image (append the timestamp to the filename)
$max_file = "3"; // Maximum file size in MB
$max_width = "500"; // Max width allowed for the large image
$thumb_width = "100"; // Width of thumbnail image
$thumb_height = "100"; // Height of thumbnail image
// Only one of these image types should be allowed for upload
$allowed_image_types = array('image/pjpeg'=>"jpg",'image/jpeg'=>"jpg",'image/jpg'=>"jpg",'image/png'=>"png",'image/x-png'=>"png",'image/gif'=>"gif");
$allowed_image_ext = array_unique($allowed_image_types); // do not change this
$image_ext = ""; // initialise variable, do not change this.
foreach ($allowed_image_ext as $mime_type => $ext)
function resizeImage($image,$width,$height,$scale) {
list($imagewidth, $imageheight, $imageType) = getimagesize($image);
$imageType = image_type_to_mime_type($imageType);
$newImageWidth = ceil($width * $scale);
$newImageHeight = ceil($height * $scale);
$newImage = imagecreatetruecolor($newImageWidth,$newImageHeight);
switch($imageType) {
case "image/gif":
$source=imagecreatefromgif($image);
break;
case "image/pjpeg":
case "image/jpeg":
case "image/jpg":
$source=imagecreatefromjpeg($image);
break;
case "image/png":
case "image/x-png":
$source=imagecreatefrompng($image);
break;
}
imagecopyresampled($newImage,$source,0,0,0,0,$newImageWidth,$newImageHeight,$width,$height);
switch($imageType) {
case "image/gif":
imagegif($newImage,$image);
break;
case "image/pjpeg":
case "image/jpeg":
case "image/jpg":
imagejpeg($newImage,$image,90);
break;
case "image/png":
case "image/x-png":
imagepng($newImage,$image);
break;
}
chmod($image, 0777);
return $image;
}
//You do not need to alter these functions
function resizeThumbnailImage($thumb_image_name, $image, $width, $height, $start_width, $start_height, $scale){
list($imagewidth, $imageheight, $imageType) = getimagesize($image);
$imageType = image_type_to_mime_type($imageType);
$newImageWidth = ceil($width * $scale);
$newImageHeight = ceil($height * $scale);
$newImage = imagecreatetruecolor($newImageWidth,$newImageHeight);
switch($imageType) {
case "image/gif":
$source=imagecreatefromgif($image);
break;
case "image/pjpeg":
case "image/jpeg":
case "image/jpg":
$source=imagecreatefromjpeg($image);
break;
case "image/png":
case "image/x-png":
$source=imagecreatefrompng($image);
break;
}
imagecopyresampled($newImage,$source,0,0,$start_width,$start_height,$newImageWidth,$newImageHeight,$width,$height);
switch($imageType) {
case "image/gif":
imagegif($newImage,$thumb_image_name);
break;
case "image/pjpeg":
case "image/jpeg":
case "image/jpg":
imagejpeg($newImage,$thumb_image_name,90);
break;
case "image/png":
case "image/x-png":
imagepng($newImage,$thumb_image_name);
break;
}
chmod($thumb_image_name, 0777);
return $thumb_image_name;
}
//You do not need to alter these functions
function getHeight($image) {
$size = getimagesize($image);
$height = $size[1];
return $height;
}
//You do not need to alter these functions
function getWidth($image) {
$size = getimagesize($image);
$width = $size[0];
return $width;
}
//Image Locations
$large_image_location = $upload_path.$large_image_name.$_SESSION['user_file_ext'];
$thumb_image_location = $upload_path.$thumb_image_name.$_SESSION['user_file_ext'];
//Create the upload directory with the right permissions if it doesn't exist
if(!is_dir($upload_dir)){
mkdir($upload_dir, 0777);
chmod($upload_dir, 0777);
}
//Check to see if any images with the same name already exist
if(file_exists($large_image_location)){
if(file_exists($thumb_image_location)){
$thumb_photo_exists = "<img src=\"".$upload_path.$thumb_image_name.$_SESSION['user_file_ext']."\" alt=\"Thumbnail Image\"/>";
}else{
$thumb_photo_exists = "";
}
$large_photo_exists = "<img src=\"".$upload_path.$large_image_name.$_SESSION['user_file_ext']."\" alt=\"Large Image\"/>";
}else{
$large_photo_exists = "";
$thumb_photo_exists = "";
}
// echo $large_image_location;
// echo strlen($large_photo_exists);
if (isset($_POST["upload"])) {
//Get the file information
$userfile_name = $_FILES['image']['name'];
$userfile_tmp = $_FILES['image']['tmp_name'];
$userfile_size = $_FILES['image']['size'];
$userfile_type = $_FILES['image']['type'];
$filename = basename($_FILES['image']['name']);
$file_ext = strtolower(substr($filename, strrpos($filename, '.') + 1));
//Only process if the file is a JPG, PNG or GIF and below the allowed limit
if((!empty($_FILES["image"])) && ($_FILES['image']['error'] == 0)) {
foreach ($allowed_image_types as $mime_type => $ext) {
//loop through the specified image types and if they match the extension then break out
//everything is ok so go and check file size
if($file_ext==$ext && $userfile_type==$mime_type){
$error = "";
break;
}else{
$error = "อนุญาตเฉพาะไฟล์ที่มีนามสกุล <strong>".$image_ext."</strong> เท่านั้น<br />";
}
}
//check if the file size is above the allowed limit
if ($userfile_size > ($max_file*1048576)) {
$error.= "Images must be under ".$max_file."MB in size";
}
}else{
$error= "กรุณาเลือกรูปภาพที่จะอัพโหลด";
}
//Everything is ok, so we can upload the image.
if (strlen($error)==0){
$oldlage = $upload_path.$_SESSION['usrid']."_resize"."_".$_SESSION['usrpic'];
$oldthumb = $upload_path.$_SESSION['usrid']."_thumbnail"."_".$_SESSION['usrpic'];
if(file_exists($oldlage)){
unlink($oldlage);
if(file_exists($oldthumb)){
unlink($oldthumb);
}
}
if (isset($_FILES['image']['name'])){
//this file could now has an unknown file extension (we hope it's one of the ones set above!)
$large_image_location = $large_image_location.".".$file_ext;
$thumb_image_location = $thumb_image_location.".".$file_ext;
//put the file ext in the session so we know what file to look for once its uploaded
$_SESSION['user_file_ext']=".".$file_ext;
move_uploaded_file($userfile_tmp, $large_image_location);
chmod($large_image_location, 0777);
$width = getWidth($large_image_location);
$height = getHeight($large_image_location);
//Scale the image if it is greater than the width set above
if ($width > $max_width){
$scale = $max_width/$width;
$uploaded = resizeImage($large_image_location,$width,$height,$scale);
}else{
$scale = 1;
$uploaded = resizeImage($large_image_location,$width,$height,$scale);
}
//Delete the thumbnail file so the user can create a new one
if (file_exists($thumb_image_location)) {
unlink($thumb_image_location);
}
}
//Refresh the page to show the new uploaded image
header("location:".$_SERVER["PHP_SELF"]);
exit();
}
}
if (isset($_POST["upload_thumbnail"]) && strlen($large_photo_exists)>0) {
//Get the new coordinates to crop the image.
$x1 = $_POST["x1"];
$y1 = $_POST["y1"];
$x2 = $_POST["x2"];
$y2 = $_POST["y2"];
$w = $_POST["w"];
$h = $_POST["h"];
//Scale the image to the thumb_width set above
$scale = $thumb_width/$w;
$cropped = resizeThumbnailImage($thumb_image_location, $large_image_location,$w,$h,$x1,$y1,$scale);
//Reload the page again to view the thumbnail
header("location:".$_SERVER["PHP_SELF"]);
exit();
}
if ($_GET['a']=="delete" && strlen($_GET['t'])>0){
//get the file locations
$large_image_location = $upload_path.$large_image_prefix.$_GET['t'];
$thumb_image_location = $upload_path.$thumb_image_prefix.$_GET['t'];
if (file_exists($large_image_location)) {
unlink($large_image_location);
}
if (file_exists($thumb_image_location)) {
unlink($thumb_image_location);
}
$sql = "UPDATE friend_list SET pic='0' WHERE pic='".$_SESSION['usrpic']."'";
mysql_query($sql);
header("location:".$_SERVER["PHP_SELF"]);
exit();
}
?>
<!doctype html>
<html>
<head>
<meta charset="utf-8">
<meta name="viewport" content="width=device-width">
<meta name="viewport" content="initial-scale=1.0">
<link rel="stylesheet" href="style.css" type="text/css">
<title>อัปโหลดรูป</title>
<script language="javascript" type="text/javascript" src="css/jquery-1.7.min.js"></script>
</head>
<body>
<div class="main-wrapper">
<div class="sec-header mobile">
<div class="menu-icon">เมนูหลัก</div>
<ul>
<li><a href="index.php">หน้าแรก</a></li>
<li><a href="addform.php">เพิ่มรายชื่อ</a></li>
</ul>
</div>
<div class="sec-header desktop">
<ul>
<li><a href="index.php"><img src="images/logo_new.png" title="อัปโหลดรูป" /></a></li>
<li><a href="index.php">หน้าแรก</a></li>
<li><a href="addform.php">เพิ่มรายชื่อ</a></li>
</ul>
</div>
<div class="sec-content">
<td class="content">
<?php
//Only display the javacript if an image has been uploaded
if(strlen($large_photo_exists)>0){
$current_large_image_width = getWidth($large_image_location);
$current_large_image_height = getHeight($large_image_location);?>
<script type="text/javascript">
function preview(img, selection) {
var scaleX = <?php echo $thumb_width;?> / selection.width;
var scaleY = <?php echo $thumb_height;?> / selection.height;
$('#thumbnail + div > img').css({
width: Math.round(scaleX * <?php echo $current_large_image_width;?>) + 'px',
height: Math.round(scaleY * <?php echo $current_large_image_height;?>) + 'px',
marginLeft: '-' + Math.round(scaleX * selection.x1) + 'px',
marginTop: '-' + Math.round(scaleY * selection.y1) + 'px'
});
$('#x1').val(selection.x1);
$('#y1').val(selection.y1);
$('#x2').val(selection.x2);
$('#y2').val(selection.y2);
$('#w').val(selection.width);
$('#h').val(selection.height);
}
$(document).ready(function () {
$('#save_thumb').click(function() {
var x1 = $('#x1').val();
var y1 = $('#y1').val();
var x2 = $('#x2').val();
var y2 = $('#y2').val();
var w = $('#w').val();
var h = $('#h').val();
if(x1=="" || y1=="" || x2=="" || y2=="" || w=="" || h==""){
alert("You must make a selection first");
return false;
}else{
return true;
}
});
});
$(window).load(function () {
$('#thumbnail').imgAreaSelect({ aspectRatio: '1:<?php echo $thumb_height/$thumb_width;?>', onSelectChange: preview });
});
</script>
<?php }?>
<div id="divform">
<?php
if(file_exists($upload_path.$_SESSION['usrid']."_resize"."_".$_SESSION['usrpic'])){
echo "<p id='oldpich1'>ภาพเดิมของคุณ</p>";
echo '<p id="oldpic"><img src="'.$upload_path.$_SESSION['usrid']."_thumbnail"."_".$_SESSION['usrpic'].'" /></p>';
echo "ต้องการลบภาพเดิม <a href=\"".$_SERVER["PHP_SELF"]."?a=delete&t=".$_SESSION['usrpic']."\">คลิก</a><br /><hr />";
}
//Display error message if there are any
if(strlen($error)>0){
echo "<ul><li><strong>เกิดข้อผิดพลาด!</strong></li><li>".$error."</li></ul>";
}
if(strlen($large_photo_exists)>0 && strlen($thumb_photo_exists)>0){
$sql = "UPDATE friend_list SET pic='".$_SESSION['random_key'].$_SESSION['user_file_ext']."' WHERE id='".$_SESSION['usrid']."'";
$query = mysql_query($sql);
echo $large_photo_exists." ".$thumb_photo_exists;
// echo "<p><a href=\"".$_SERVER["PHP_SELF"]."?a=delete&t=".$_SESSION['random_key'].$_SESSION['user_file_ext']."\">Delete images</a></p>";
// echo "<p><a href=\"".$_SERVER["PHP_SELF"]."\">Upload another</a></p>";
//Clear the time stamp session and user file extension
$_SESSION['random_key']= "";
$_SESSION['user_file_ext']= "";
$_SESSION['usrid'] = "";
unset($_SESSION['usrid']);
$_SESSION['usrpic'] = "";
unset($_SESSION['usrpic']);
$js=<<<JS
<script>
alert('จัดเก็บรูปเรียบร้อยแล้ว');
location.replace('index.php');
</script>
JS;
echo $js;
}else{
if(strlen($large_photo_exists)>0){?>
<h2>อัปโหลดรูปประจำตัว</h2>
<p id="thumdesc">คลิ้กเมาท์ซ้ายค้างไว้ที่รูปแล้วลาก</p>
<div align="center">
<img src="<?php echo $upload_path.$large_image_name.$_SESSION['user_file_ext'];?>" style="float: left; margin-right: 10px;" id="thumbnail" alt="Create Thumbnail" />
<div style="border:1px #e5e5e5 solid; float:left; position:relative; overflow:hidden; width:<?php echo $thumb_width;?>px; height:<?php echo $thumb_height;?>px;">
<img src="<?php echo $upload_path.$large_image_name.$_SESSION['user_file_ext'];?>" style="position: relative;" alt="Thumbnail Preview" />
</div>
<br style="clear:both;"/>
<form name="thumbnail" action="<?php echo $_SERVER["PHP_SELF"];?>" method="post">
<input type="hidden" name="x1" value="" id="x1" />
<input type="hidden" name="y1" value="" id="y1" />
<input type="hidden" name="x2" value="" id="x2" />
<input type="hidden" name="y2" value="" id="y2" />
<input type="hidden" name="w" value="" id="w" />
<input type="hidden" name="h" value="" id="h" />
<br />
<input type="submit" name="upload_thumbnail" value="จัดเก็บภาพย่อ" id="save_thumb" />
</form>
</div>
<hr />
<?php
}
}
if(!strlen($large_photo_exists)>0){
?>
<h2>Upload Photo</h2>
<form name="photo" enctype="multipart/form-data" action="<?php echo $_SERVER["PHP_SELF"];?>" method="post">
เลือกรูป» <input type="file" name="image" size="30" /> <input type="submit" name="upload" value="Upload" />
</form>
<br />
<!-- <hr />
<p id="picuploadfooter">ËÒ¡äÁèµéͧ¡ÒÃÍѾâËÅ´ ¡ÃØ³Ò <?php echo "<a href='index.php'>จัดเก็บรูปเรียบร้อยแล้ว</a>"; ?></p> -->
<?php
}
?>
<div id="callback">
</div>
<div class="sec-footer">
© copyright 2016 - linefriend.me
</div>
<script language="javascript">
var initHeight,toggle;
$(function(){
initHeight=160;
toggle=false;
$('.sec-header.mobile ul').css({'height':'0px'});
$('.menu-icon').click(function(e){
e.preventDefault();
toggle=!toggle;
if(toggle){
$('.sec-header.mobile ul').animate({
height: initHeight+'px'
}, 400);
$('.menu-icon').html("ปิดเมนู");
}else{
$('.sec-header.mobile ul').animate({
height: '0px'
}, 400);
$('.menu-icon').html("เมนูหลัก");
}
});
});
</script>
</body>
</html>
<?php
mysql_close($con);
}else{
echo "// คุณเข้าใช้ส่วนนี้ไม่ถูกต้อง!!";
}
?>
Tag : PHP
|
|
|
|
|
|
Date :
2016-01-11 18:34:15 |
By :
newaiman |
View :
1045 |
Reply :
1 |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
Code (PHP)
$useragent=$_SERVER['HTTP_USER_AGENT'];
if(preg_match('/(android|bb\d+|meego).+mobile|avantgo|bada\/|blackberry|blazer|compal|elaine|fennec|hiptop|iemobile|ip(hone|od)|iris|kindle|lge |maemo|midp|mmp|netfront|opera m(ob|in)i|palm( os)?|phone|p(ixi|re)\/|plucker|pocket|psp|series(4|6)0|symbian|treo|up\.(browser|link)|vodafone|wap|windows (ce|phone)|xda|xiino/i',$useragent)||preg_match('/1207|6310|6590|3gso|4thp|50[1-6]i|770s|802s|a wa|abac|ac(er|oo|s\-)|ai(ko|rn)|al(av|ca|co)|amoi|an(ex|ny|yw)|aptu|ar(ch|go)|as(te|us)|attw|au(di|\-m|r |s )|avan|be(ck|ll|nq)|bi(lb|rd)|bl(ac|az)|br(e|v)w|bumb|bw\-(n|u)|c55\/|capi|ccwa|cdm\-|cell|chtm|cldc|cmd\-|co(mp|nd)|craw|da(it|ll|ng)|dbte|dc\-s|devi|dica|dmob|do(c|p)o|ds(12|\-d)|el(49|ai)|em(l2|ul)|er(ic|k0)|esl8|ez([4-7]0|os|wa|ze)|fetc|fly(\-|_)|g1 u|g560|gene|gf\-5|g\-mo|go(\.w|od)|gr(ad|un)|haie|hcit|hd\-(m|p|t)|hei\-|hi(pt|ta)|hp( i|ip)|hs\-c|ht(c(\-| |_|a|g|p|s|t)|tp)|hu(aw|tc)|i\-(20|go|ma)|i230|iac( |\-|\/)|ibro|idea|ig01|ikom|im1k|inno|ipaq|iris|ja(t|v)a|jbro|jemu|jigs|kddi|keji|kgt( |\/)|klon|kpt |kwc\-|kyo(c|k)|le(no|xi)|lg( g|\/(k|l|u)|50|54|\-[a-w])|libw|lynx|m1\-w|m3ga|m50\/|ma(te|ui|xo)|mc(01|21|ca)|m\-cr|me(rc|ri)|mi(o8|oa|ts)|mmef|mo(01|02|bi|de|do|t(\-| |o|v)|zz)|mt(50|p1|v )|mwbp|mywa|n10[0-2]|n20[2-3]|n30(0|2)|n50(0|2|5)|n7(0(0|1)|10)|ne((c|m)\-|on|tf|wf|wg|wt)|nok(6|i)|nzph|o2im|op(ti|wv)|oran|owg1|p800|pan(a|d|t)|pdxg|pg(13|\-([1-8]|c))|phil|pire|pl(ay|uc)|pn\-2|po(ck|rt|se)|prox|psio|pt\-g|qa\-a|qc(07|12|21|32|60|\-[2-7]|i\-)|qtek|r380|r600|raks|rim9|ro(ve|zo)|s55\/|sa(ge|ma|mm|ms|ny|va)|sc(01|h\-|oo|p\-)|sdk\/|se(c(\-|0|1)|47|mc|nd|ri)|sgh\-|shar|sie(\-|m)|sk\-0|sl(45|id)|sm(al|ar|b3|it|t5)|so(ft|ny)|sp(01|h\-|v\-|v )|sy(01|mb)|t2(18|50)|t6(00|10|18)|ta(gt|lk)|tcl\-|tdg\-|tel(i|m)|tim\-|t\-mo|to(pl|sh)|ts(70|m\-|m3|m5)|tx\-9|up(\.b|g1|si)|utst|v400|v750|veri|vi(rg|te)|vk(40|5[0-3]|\-v)|vm40|voda|vulc|vx(52|53|60|61|70|80|81|83|85|98)|w3c(\-| )|webc|whit|wi(g |nc|nw)|wmlb|wonu|x700|yas\-|your|zeto|zte\-/i',substr($useragent,0,4)))
{
// ไม่ต้อง crop
}
else
{
// มีการ crop
}
Manjeet Kumar Nai @ SO
|
|
|
|
|
Date :
2020-07-01 18:01:06 |
By :
PhrayaDev |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
Load balance : Server 01
|