ПОЛУЧИТЕ параметры в URL-адресе с помощью CodeIgniter
-
22-07-2019 - |
Вопрос
Я знаю, что CodeIgniter отключает ПОЛУЧЕНИЕ параметров по умолчанию.
Но поскольку все делается в POST, разве вас не раздражают запросы на повторную отправку данных, если вы когда-либо нажимаете "Назад" после отправки формы?
Это меня раздражает, но я не уверен, хочу ли я разрешить GET исключительно по этой причине.
Это такая большая проблема безопасности, чтобы разрешить ПОЛУЧЕНИЕ параметров тоже?
Решение
Когда я впервые начал работать с CodeIgniter, то, что я не использовал GET, действительно меня тоже оттолкнуло. Но потом я понял, что вы можете смоделировать параметры GET, манипулируя URI с помощью встроенного класса URI а>. Это фантастика, и это делает ваши URL лучше.
Или, если вам действительно нужно, чтобы GET работал, вы можете поместить это в свой контроллер:
parse_str($_SERVER['QUERY_STRING'], $_GET);
Который поместит переменные обратно в массив GET. Р>
Другие советы
Это сработало для меня:
<?php
$url = parse_url($_SERVER['REQUEST_URI']);
parse_str($url['query'], $params);
?>
Массив $params
содержит параметры, переданные после? символ
Теперь все работает нормально из CodeIgniter 2.1.0
//By default CodeIgniter enables access to the $_GET array. If for some
//reason you would like to disable it, set 'allow_get_array' to FALSE.
$config['allow_get_array'] = TRUE;
Эта функция идентична функции post, только она получает данные:
$this->input->get()
https://www.codeigniter.com/user_guide/libraries/input.html р>
Вам просто нужно включить его в config.php, и вы можете использовать $this->input->get('param_name');
для получения параметров.
parse_str($_SERVER['QUERY_STRING'],$_GET);
Сработало у меня только после того, как я добавил следующую строку в applications/config/config.php:
$config['uri_protocol'] = "PATH_INFO";
Я обнаружил, что параметры $ _GET на самом деле не нужны в CI, но Facebook и другие сайты выводят параметры GET в конец ссылок, которые были бы 404 для моего сайта CI!!Добавив строку выше в config.php, эти страницы заработали.Я надеюсь, что это поможет людям!
(из http://www.maheshchari.com/work-to-get-method-on-codeigniter/)
Вы можете включить строки запроса, если действительно настаиваете. В вашем config.php вы можете включить строки запроса:
$config['enable_query_strings'] = TRUE;
Для получения дополнительной информации вы можете посмотреть внизу этой вики-страницы: http://codeigniter.com/user_guide/general/urls.html
Тем не менее, обучение работе с чистыми URL-адресами является лучшим предложением.
" вас не раздражает повторная отправка запросов данных, если вы когда-нибудь нажмете обратно после отправки формы "
обойти это можно, перенаправив страницу, которая обрабатывает отправку формы на страницу успеха. последнее & действие " это была загрузка страницы успеха, а не отправка формы, что означает, что если пользователи сделают F5, он просто перезагрузит эту страницу и больше не отправит форму.
Если вам нужен первый параметр, используйте его.
$this->uri->segment('3');
И вам нужен второй параметр, используйте его
$this->uri->segment('4');
Имейте свой параметр улучшения многих параметров
allesklar: это немного вводит в заблуждение, поскольку скрипты и боты могут POST-данные почти так же легко, как отправка обычного запроса. Это не секрет, это часть HTTP.
Немного не в тему, но я искал функцию get в CodeIgniter, чтобы просто передавать переменные между контроллерами и получать Flashdata.
см. http://codeigniter.com/user_guide/libraries/sessions.html
Flashdata позволяет создавать быстрые данные сеанса, которые будут доступны только для следующего запроса к серверу, а затем автоматически очищаются.
MY_Input.php:
<?php
// this class extension allows for $_GET access
class MY_Input extends CI_input {
function _sanitize_globals()
{
// setting allow_get_array to true is the only real modification
$this->allow_get_array = TRUE;
parent::_sanitize_globals();
}
}
/* End of file MY_Input.php */
/* Location: .application/libraries/MY_Input.php */
MY_URI.php:
<?php
/*
| this class extension allows for $_GET access by retaining the
| standard functionality of allowing query strings to build the
| URI String, but checks if enable_query_strings is TRUE
*/
class MY_URI extends CI_URI{
function _fetch_uri_string()
{
if (strtoupper($this->config->item('uri_protocol')) == 'AUTO')
{
// If the URL has a question mark then it's simplest to just
// build the URI string from the zero index of the $_GET array.
// This avoids having to deal with $_SERVER variables, which
// can be unreliable in some environments
//
// *** THE ONLY MODIFICATION (EXTENSION) TO THIS METHOD IS TO CHECK
// IF enable_query_strings IS TRUE IN THE LINE BELOW ***
if ($this->config->item('enable_query_strings') === TRUE && is_array($_GET) && count($_GET) == 1 && trim(key($_GET), '/') != '')
{
$this->uri_string = key($_GET);
return;
}
// Is there a PATH_INFO variable?
// Note: some servers seem to have trouble with getenv() so we'll test it two ways
$path = (isset($_SERVER['PATH_INFO'])) ? $_SERVER['PATH_INFO'] : @getenv('PATH_INFO');
if (trim($path, '/') != '' && $path != "/".SELF)
{
$this->uri_string = $path;
return;
}
// No PATH_INFO?... What about QUERY_STRING?
$path = (isset($_SERVER['QUERY_STRING'])) ? $_SERVER['QUERY_STRING'] : @getenv('QUERY_STRING');
if (trim($path, '/') != '')
{
$this->uri_string = $path;
return;
}
// No QUERY_STRING?... Maybe the ORIG_PATH_INFO variable exists?
$path = str_replace($_SERVER['SCRIPT_NAME'], '', (isset($_SERVER['ORIG_PATH_INFO'])) ? $_SERVER['ORIG_PATH_INFO'] : @getenv('ORIG_PATH_INFO'));
if (trim($path, '/') != '' && $path != "/".SELF)
{
// remove path and script information so we have good URI data
$this->uri_string = $path;
return;
}
// We've exhausted all our options...
$this->uri_string = '';
}
else
{
$uri = strtoupper($this->config->item('uri_protocol'));
if ($uri == 'REQUEST_URI')
{
$this->uri_string = $this->_parse_request_uri();
return;
}
$this->uri_string = (isset($_SERVER[$uri])) ? $_SERVER[$uri] : @getenv($uri);
}
// If the URI contains only a slash we'll kill it
if ($this->uri_string == '/')
{
$this->uri_string = '';
}
}
}
/* End of file MY_URI.php */
/* Location: .application/libraries/MY_URI.php */
мой параметр равен ?uid= 4 и получаю его с помощью:
$this->uid = $this->input->get('uid', TRUE);
echo $this->uid;
мудрый
GET-параметры кэшируются веб-браузером, POST - нет. Так что с POST вам не нужно беспокоиться о кешировании, поэтому его обычно предпочитают. Р>
Вы можете попробовать это
$this->uri->segment('');
Еще проще:
curl -X POST -d "param=value¶m2=value" http://example.com/form.cgi
этот плагин довольно крутой, хотя.
Сделайте это ниже. Работал на меня. Я взял значения из поля выбора и другого текстового поля. Затем, нажав кнопку, я взял все данные в функции Javascript и перенаправил их с помощью JavaScript.
//Search Form
$(document).ready (function($){
$("#searchbtn").click(function showAlert(e){
e.preventDefault();
var cat = $('#category').val();
var srch = $('#srch').val();
if(srch==""){
alert("Search is empty :(");
}
else{
var url = baseurl+'categories/search/'+cat+'/'+srch;
window.location.href=url;
}
});
});
Приведенный выше код работал на меня. Р>