Blame view

static/plugins/webshim-gh-pages/js-webshim/dev/shims/FlashCanvas/proxy.php 2.96 KB
831eac332   zhuzhenchao   add file
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
  <?php
  
  /**
   * Proxy script to load a file from other domain
   *
   * PHP versions 4 and 5
   *
   * Copyright (c) 2010-2013 Shinya Muramatsu
   *
   * Permission is hereby granted, free of charge, to any person obtaining a
   * copy of this software and associated documentation files (the "Software"),
   * to deal in the Software without restriction, including without limitation
   * the rights to use, copy, modify, merge, publish, distribute, sublicense,
   * and/or sell copies of the Software, and to permit persons to whom the
   * Software is furnished to do so, subject to the following conditions:
   *
   * The above copyright notice and this permission notice shall be included in
   * all copies or substantial portions of the Software.
   *
   * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
   * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
   * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL
   * THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
   * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
   * FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER
   * DEALINGS IN THE SOFTWARE.
   *
   * @author     Shinya Muramatsu <revulon@gmail.com>
   * @copyright  2010-2013 Shinya Muramatsu
   * @license    http://www.opensource.org/licenses/mit-license.php  MIT License
   * @link       http://flashcanvas.net/
   * @link       http://code.google.com/p/flashcanvas/
   */
  
  function FCgetHostName() {
      if (isset($_SERVER['HTTP_X_FORWARDED_HOST'])) {
          return $_SERVER['HTTP_X_FORWARDED_HOST'];
      } else if (isset($_SERVER['HTTP_HOST'])) {
          return $_SERVER['HTTP_HOST'];
      } else {
          return $_SERVER['SERVER_NAME'];
      }
  }
  
  // Whether we check referrer or not
  define('CHECK_REFERRER', true);
  
  // If necessary, specify the host where the SWF file is located
  define('SWF_HOST_NAME', '');
  
  // Check that the request comes from the same host
  if (CHECK_REFERRER) {
      if (empty($_SERVER['HTTP_REFERER'])) {
          exit;
      }
      if (SWF_HOST_NAME) {
          $host = SWF_HOST_NAME;
      } else {
          $host = FCgetHostName();
      }
      $pattern = '#^https?://' . str_replace('.', '\.', $host) . '(:\d*)?/#';
      if (!preg_match($pattern, $_SERVER['HTTP_REFERER'])) {
          exit;
      }
  }
  
  // Check that the request has a valid URL parameter
  if (empty($_GET['url'])) {
      exit;
  }
  if (!preg_match('#^https?://#', $_GET['url'])) {
      exit;
  }
  
  // Percent-encode special characters in the URL
  $search  = array(  '%',   '#',   ' ');
  $replace = array('%25', '%23', '%20');
  $url     = str_replace($search, $replace, $_GET['url']);
  
  // Disable compression
  header('Content-Encoding: none');
  
  // Load and output the file
  if (extension_loaded('curl')) {
      // Use cURL extension
      $ch = curl_init($url);
  //  curl_setopt($ch, CURLOPT_FOLLOWLOCATION, true);
  //  curl_setopt($ch, CURLOPT_MAXREDIRS, 10);
      curl_exec($ch);
      curl_close($ch);
  } else {
      // Use the http:// wrapper
      readfile($url);
  }