imageUpload.php 2.3 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667
  1. <?php
  2. /**
  3. * @fileOverview: 本文件用于 DEMO 用途,用于提供图片上传后端的接口,接收前端的上传文件请求,返回上传成功后的 URL(绝对地址)
  4. *
  5. * 原理:
  6. * 1. 返回的接口结构为 {errno: <错误号, 无错误则为 0>, msg: <错误信息>, data: {url: <返回的 URL>}};
  7. * 2. 由于要兼容两种情况的上传:通过对话框选择本地文件上传和直接 Ctrl + V(多见于截图后),因此本文件分别进行了判断
  8. *
  9. *
  10. * 注意:
  11. * 1. 本文件的路径可以进行配置,详见 README.md 中「初始化配置」部分。
  12. * 2. 由于使用场景不同,请根据实际场景编写上传文件的处理。
  13. * 3. 本文件并没有做任何的安全方面的防护,请勿用于生产环境。
  14. *
  15. * @author: zhangbobell
  16. *
  17. * @date: 2016.07.06
  18. *
  19. */
  20. // 返回给前端的地址是绝对地址,这里是前缀
  21. $HTTP_PREFIX = 'http://localhost/kityminder-editor/';
  22. $errno = 0;
  23. $msg = 'ok';
  24. $url = '';
  25. if ((($_FILES["upload_file"]["type"] == "image/gif")
  26. || ($_FILES["upload_file"]["type"] == "image/jpeg")
  27. || ($_FILES["upload_file"]["type"] == "image/jpg")
  28. || ($_FILES["upload_file"]["type"] == "image/png"))
  29. && ($_FILES["upload_file"]["size"] < 1 * 1000 * 1000)) {
  30. if ($_FILES["upload_file"]["error"] > 0) {
  31. $errno = 414;
  32. $msg = $_FILES["upload_file"]["error"];
  33. } else {
  34. // 分为两种情况 `Ctrl + V` 和普通上传
  35. if ($_FILES["upload_file"]["name"] === 'blob') {
  36. $ext_name = 'png';
  37. } else {
  38. $ext_name = array_pop(explode('.', $_FILES["upload_file"]["name"]));
  39. }
  40. $sha1_name = sha1_file($_FILES["upload_file"]["tmp_name"]) . '.' . $ext_name;
  41. move_uploaded_file($_FILES["upload_file"]["tmp_name"], "upload/" . $sha1_name);
  42. $url = $HTTP_PREFIX . "server/upload/" . $sha1_name;
  43. }
  44. } else {
  45. $errno = 416;
  46. $msg = 'File is invalid';
  47. }
  48. $result = array(
  49. 'errno' => $errno,
  50. 'msg' => $msg,
  51. 'data' => array(
  52. 'url' => $url
  53. )
  54. );
  55. echo json_encode($result);