Javascript проверки формы на стороне сервера, это возможно? - PullRequest
2 голосов
/ 06 января 2012

Как я могу заставить эту форму работать на стороне сервера, а не на стороне клиента. У меня есть следующий код:

<script type="text/javascript">
function validateForm()
{
    var namef=document.forms["orderform1"].elements["name"].value;
    var emailf=document.forms["orderform1"].elements["email"].value;
    var addressf=document.forms["orderform1"].elements["address1"].value;
    var statef=document.forms["orderform1"].elements["state"].value;
    var pincodef=document.forms["orderform1"]["pincode"].value;
    var phonef=document.forms["orderform1"]["phone"].value;

    var nameregex=/^[a-zA-Z]+\s?[a-zA-Z]+$/;
    var emailregex=/^[a-zA-Z0-9\_\-\.]+\@[a-zA-Z0-9\_\-\.]+$/;
    var addressregex = /^[0-9a-zA-Z\,\s]+$/;
    var stateregex=/^[a-zA-Z]+\s?[a-zA-Z]+$/;
    var pincoderegex=/^[0-9]{4,6}$/;
    var phoneregex=/^\+?[0-9]{8,12}$/;
    if(namef.match(nameregex))
                {
                     if (emailf.match(emailregex)) 
                     {
                        if (addressf.match(addressregex)) 
                        {
                            if (statef.match(stateregex))
                            {
                                if (pincodef.match(pincoderegex))
                                {
                                    if (phonef.match(phoneregex))
                                    {
                                        return true;
                                    }
                                    else
                                    {
                                        alert('Invalid Phone number.');
                                        return false;
                                    }
                                }
                                else
                                {
                                    alert('Invalid PIncode');
                                    return false;
                                }
                            }
                            else
                            {
                                alert('Invalid State');
                                return false;
                            }
                        } 
                        else 
                        {
                            alert('Address Empty or Contains illegal characters');
                            return false;
                        }
                     } 
                     else 
                     {
                        alert('Email incorrect');
                        return false;
                    }
                }
                else
                {
                    alert("Please Enter a Valid Name!");
                    return false;
                }
}
</script>

И форма html:

<form name="orderform1" action="" onsubmit="return validateForm()" method="post" id="orderform">
          <ol>
            <li>
              <label for="name">Your Name:*</label>
              <input id="name" name="name" class="text" />
            </li>
            <li>
              <label for="email">E-Mail:*</label>
              <input id="email" name="email" class="text" />
            </li>
            <li>
              <label for="address1">Address Line 1:*</label>
              <input id="address1" name="address1" class="text" />
            </li>
            <li>
              <label for="address2">Address Line 2:</label>
              <input id="address2" name="address2" class="text" />
            </li>
            <li>
              <label for="state">State/Province*:</label>
              <input id="state" name="state" class="text" />
            </li>
            <li>
              <label for="address">City:</label>
              <input id="address" name="address" class="text" />
            </li>
            <li>
              <label for="pincode">Pin Code:*</label>
              <input id="pincode" name="pincode" class="text" />
            </li>
            <li>
            <label for="country">Country:*</label>
            <select name="country">
<option value="AF">Afghanistan</option>
<option value="AX">Ã…Land Islands</option>
<option value="AL">Albania</option>
<option value="DZ">Algeria</option>
<option value="AS">American Samoa</option>
<option value="AD">Andorra</option>
<option value="AO">Angola</option>
<option value="AI">Anguilla</option>
<option value="AQ">Antarctica</option>
<option value="AG">Antigua And Barbuda</option>
<option value="AR">Argentina</option>
<option value="AM">Armenia</option>
<option value="AW">Aruba</option>
<option value="AU">Australia</option>
<option value="AT">Austria</option>
<option value="AZ">Azerbaijan</option>
<option value="BS">Bahamas</option>
<option value="BH">Bahrain</option>
<option value="BD">Bangladesh</option>
<option value="BB">Barbados</option>
<option value="BY">Belarus</option>
<option value="BE">Belgium</option>
<option value="BZ">Belize</option>
<option value="BJ">Benin</option>
<option value="BM">Bermuda</option>
<option value="BT">Bhutan</option>
<option value="BO">Bolivia</option>
<option value="BA">Bosnia And Herzegovina</option>
<option value="BW">Botswana</option>
<option value="BV">Bouvet Island</option>
<option value="BR">Brazil</option>
<option value="IO">British Indian Ocean Territory</option>
<option value="BN">Brunei Darussalam</option>
<option value="BG">Bulgaria</option>
<option value="BF">Burkina Faso</option>
<option value="BI">Burundi</option>
<option value="KH">Cambodia</option>
<option value="CM">Cameroon</option>
<option value="CA">Canada</option>
<option value="CV">Cape Verde</option>
<option value="KY">Cayman Islands</option>
<option value="CF">Central African Republic</option>
<option value="TD">Chad</option>
<option value="CL">Chile</option>
<option value="CN">China</option>
<option value="CX">Christmas Island</option>
<option value="CC">Cocos (Keeling) Islands</option>
<option value="CO">Colombia</option>
<option value="KM">Comoros</option>
<option value="CG">Congo</option>
<option value="CD">Congo, The Democratic Republic Of The</option>
<option value="CK">Cook Islands</option>
<option value="CR">Costa Rica</option>
<option value="CI">Cote D'Ivoire</option>
<option value="HR">Croatia</option>
<option value="CU">Cuba</option>
<option value="CY">Cyprus</option>
<option value="CZ">Czech Republic</option>
<option value="DK">Denmark</option>
<option value="DJ">Djibouti</option>
<option value="DM">Dominica</option>
<option value="DO">Dominican Republic</option>
<option value="EC">Ecuador</option>
<option value="EG">Egypt</option>
<option value="SV">El Salvador</option>
<option value="GQ">Equatorial Guinea</option>
<option value="ER">Eritrea</option>
<option value="EE">Estonia</option>
<option value="ET">Ethiopia</option>
<option value="FK">Falkland Islands (Malvinas)</option>
<option value="FO">Faroe Islands</option>
<option value="FJ">Fiji</option>
<option value="FI">Finland</option>
<option value="FR">France</option>
<option value="GF">French Guiana</option>
<option value="PF">French Polynesia</option>
<option value="TF">French Southern Territories</option>
<option value="GA">Gabon</option>
<option value="GM">Gambia</option>
<option value="GE">Georgia</option>
<option value="DE">Germany</option>
<option value="GH">Ghana</option>
<option value="GI">Gibraltar</option>
<option value="GR">Greece</option>
<option value="GL">Greenland</option>
<option value="GD">Grenada</option>
<option value="GP">Guadeloupe</option>
<option value="GU">Guam</option>
<option value="GT">Guatemala</option>
<option value=" Gg">Guernsey</option>
<option value="GN">Guinea</option>
<option value="GW">Guinea-Bissau</option>
<option value="GY">Guyana</option>
<option value="HT">Haiti</option>
<option value="HM">Heard Island And Mcdonald Islands</option>
<option value="VA">Holy See (Vatican City State)</option>
<option value="HN">Honduras</option>
<option value="HK">Hong Kong</option>
<option value="HU">Hungary</option>
<option value="IS">Iceland</option>
<option value="IN">India</option>
<option value="ID">Indonesia</option>
<option value="IR">Iran, Islamic Republic Of</option>
<option value="IQ">Iraq</option>
<option value="IE">Ireland</option>
<option value="IM">Isle Of Man</option>
<option value="IL">Israel</option>
<option value="IT">Italy</option>
<option value="JM">Jamaica</option>
<option value="JP">Japan</option>
<option value="JE">Jersey</option>
<option value="JO">Jordan</option>
<option value="KZ">Kazakhstan</option>
<option value="KE">Kenya</option>
<option value="KI">Kiribati</option>
<option value="KP">Korea, Democratic People'S Republic Of</option>
<option value="KR">Korea, Republic Of</option>
<option value="KW">Kuwait</option>
<option value="KG">Kyrgyzstan</option>
<option value="LA">Lao People'S Democratic Republic</option>
<option value="LV">Latvia</option>
<option value="LB">Lebanon</option>
<option value="LS">Lesotho</option>
<option value="LR">Liberia</option>
<option value="LY">Libyan Arab Jamahiriya</option>
<option value="LI">Liechtenstein</option>
<option value="LT">Lithuania</option>
<option value="LU">Luxembourg</option>
<option value="MO">Macao</option>
<option value="MK">Macedonia, The Former Yugoslav Republic Of</option>
<option value="MG">Madagascar</option>
<option value="MW">Malawi</option>
<option value="MY">Malaysia</option>
<option value="MV">Maldives</option>
<option value="ML">Mali</option>
<option value="MT">Malta</option>
<option value="MH">Marshall Islands</option>
<option value="MQ">Martinique</option>
<option value="MR">Mauritania</option>
<option value="MU">Mauritius</option>
<option value="YT">Mayotte</option>
<option value="MX">Mexico</option>
<option value="FM">Micronesia, Federated States Of</option>
<option value="MD">Moldova, Republic Of</option>
<option value="MC">Monaco</option>
<option value="MN">Mongolia</option>
<option value="MS">Montserrat</option>
<option value="MA">Morocco</option>
<option value="MZ">Mozambique</option>
<option value="MM">Myanmar</option>
<option value="NA">Namibia</option>
<option value="NR">Nauru</option>
<option value="NP">Nepal</option>
<option value="NL">Netherlands</option>
<option value="AN">Netherlands Antilles</option>
<option value="NC">New Caledonia</option>
<option value="NZ">New Zealand</option>
<option value="NI">Nicaragua</option>
<option value="NE">Niger</option>
<option value="NG">Nigeria</option>
<option value="NU">Niue</option>
<option value="NF">Norfolk Island</option>
<option value="MP">Northern Mariana Islands</option>
<option value="NO">Norway</option>
<option value="OM">Oman</option>
<option value="PK">Pakistan</option>
<option value="PW">Palau</option>
<option value="PS">Palestinian Territory, Occupied</option>
<option value="PA">Panama</option>
<option value="PG">Papua New Guinea</option>
<option value="PY">Paraguay</option>
<option value="PE">Peru</option>
<option value="PH">Philippines</option>
<option value="PN">Pitcairn</option>
<option value="PL">Poland</option>
<option value="PT">Portugal</option>
<option value="PR">Puerto Rico</option>
<option value="QA">Qatar</option>
<option value="RE">Reunion</option>
<option value="RO">Romania</option>
<option value="RU">Russian Federation</option>
<option value="RW">Rwanda</option>
<option value="SH">Saint Helena</option>
<option value="KN">Saint Kitts And Nevis</option>
<option value="LC">Saint Lucia</option>
<option value="PM">Saint Pierre And Miquelon</option>
<option value="VC">Saint Vincent And The Grenadines</option>
<option value="WS">Samoa</option>
<option value="SM">San Marino</option>
<option value="ST">Sao Tome And Principe</option>
<option value="SA">Saudi Arabia</option>
<option value="SN">Senegal</option>
<option value="CS">Serbia And Montenegro</option>
<option value="SC">Seychelles</option>
<option value="SL">Sierra Leone</option>
<option value="SG">Singapore</option>
<option value="SK">Slovakia</option>
<option value="SI">Slovenia</option>
<option value="SB">Solomon Islands</option>
<option value="SO">Somalia</option>
<option value="ZA">South Africa</option>
<option value="GS">South Georgia And The South Sandwich Islands</option>
<option value="ES">Spain</option>
<option value="LK">Sri Lanka</option>
<option value="SD">Sudan</option>
<option value="SR">Suriname</option>
<option value="SJ">Svalbard And Jan Mayen</option>
<option value="SZ">Swaziland</option>
<option value="SE">Sweden</option>
<option value="CH">Switzerland</option>
<option value="SY">Syrian Arab Republic</option>
<option value="TW">Taiwan, Province Of China</option>
<option value="TJ">Tajikistan</option>
<option value="TZ">Tanzania, United Republic Of</option>
<option value="TH">Thailand</option>
<option value="TL">Timor-Leste</option>
<option value="TG">Togo</option>
<option value="TK">Tokelau</option>
<option value="TO">Tonga</option>
<option value="TT">Trinidad And Tobago</option>
<option value="TN">Tunisia</option>
<option value="TR">Turkey</option>
<option value="TM">Turkmenistan</option>
<option value="TC">Turks And Caicos Islands</option>
<option value="TV">Tuvalu</option>
<option value="UG">Uganda</option>
<option value="UA">Ukraine</option>
<option value="AE">United Arab Emirates</option>
<option value="GB">United Kingdom</option>
<option value="US">United States</option>
<option value="UM">United States Minor Outlying Islands</option>
<option value="UY">Uruguay</option>
<option value="UZ">Uzbekistan</option>
<option value="VU">Vanuatu</option>
<option value="VE">Venezuela</option>
<option value="VN">Viet Nam</option>
<option value="VG">Virgin Islands, British</option>
<option value="VI">Virgin Islands, U.S.</option>
<option value="WF">Wallis And Futuna</option>
<option value="EH">Western Sahara</option>
<option value="YE">Yemen</option>
<option value="ZM">Zambia</option>
<option value="ZW">Zimbabwe</option>
</select>
            <li>
              <label for="phone">Phone Number(With Country Code):*</label>
              <input id="phone" name="phone" class="text" />
            </li>
            <li class="buttons">
              <input type="submit" name="imageField" id="imageField"  value="Proceed to Payment" class="send" />
              <div class="clr"></div>
            </li>
          </ol>
        </form>

Ответы [ 7 ]

2 голосов
/ 06 января 2012

Это зависит от того, что вы понимаете под "_ работа на стороне сервера, а не на стороне клиента _".

Если под вышесказанным вы понимаете перенос проверки на сторону сервера, то да, это определенно возможно. Одним из самых простых примеров является PHP - см. Пример PIN-кода ниже:

<?php

$pincode = $_POST['pincode'];
$pincoderegex = '/^[0-9]{4,6}$/';
if (!preg_match($pincoderegex, $pincode)) {
    echo 'Invalid PIN code';
}

?>

(размещено где-то на странице PHP с формой)

Сделайте это для других полей по аналогии, и вы должны получить эффект, аналогичный тому, который есть в JavaScript.

0 голосов
/ 06 января 2012

Если ваша цель состоит в том, чтобы написать код проверки только один раз, то лучший вариант, если вы используете реляционную базу данных для хранения переданных значений, - это написать хорошие проверочные ограничения для столбцов.Затем при попытке вставить данные в таблицу вы получите ошибку базы данных, которую вы можете отобразить на своей странице.

Это не очень удобно для пользователя, поскольку пользователь не получает немедленной обратной связи по введенным данным, но это лучший способ гарантировать, что у вас есть хорошие данные независимо от того, как вы вводите их в базу данных.

0 голосов
/ 06 января 2012

(Новый ответ, так как комментарии к вопросу подразумевают, что вы хотите повторно использовать JS на сервере, что отличается от того, как я его интерпретировал изначально.)

В Википедии есть списоксерверных JavaScript-решений , из которых node.js , вероятно, является самым популярным на сегодняшний день.

Также есть интерфейсы к движкам V8 и Rhino JavaScript для многих языков программирования, которые вы можетеиспользуйте для интеграции с существующим кодом на стороне сервера.

Однако подавляющее большинство вашего кода не предназначено для многократного использования на стороне сервера, так как большая часть из них - манипуляция DOM для извлечения данных из формы (и на сервере вы будете извлекать его из HTTP, а не из DOM) или будете отображать логику (стек предупреждений) для отрисовки сообщений об ошибках (опять же, их нельзя использовать повторно, поскольку сервер должен отвечать по HTTP и не взаимодействовать с API-интерфейсами браузера).

Единственные фрагменты кода, которые вы можете использовать повторно, это регулярные выражения…легко переносим на другие языки.Вероятно, для этой ситуации потребуется больше усилий, чем стоит реализовать решение JS на сервере.

0 голосов
/ 06 января 2012

В качестве стандартного подхода первый набор проверок всегда выполняется на стороне клиента. Это может включать в себя базовые проверки, такие как текстовое поле, не пустое и т. Д. Однако проверки данных, которые должны проверяться в вашей базе данных, обычно выполняются после отправки формы. Если проверки не пройдены, форма перезагружается с выделенными ошибочными полями.

Если вы хотите проверять ввод пользователя по вашей базе данных при вводе (например, подтвердить, доступно ли введенное ими имя пользователя), вы можете сделать Ajax-вызов на ваш сервер, когда текстовое поле теряет фокус, и вернуть, если данные действительны или нет.

0 голосов
/ 06 января 2012

NODE.JS и РУБИН НА РЕЙЛЯХ.,,,,.

0 голосов
/ 06 января 2012

В двух словах:

  1. Выберите язык программирования
  2. Напишите обработчик формы на этом языке, используя его стандартные библиотеки для анализа данных формы и взаимодействия с HTTP
  3. Настройте сервер для запуска этого обработчика формы для запросов к URI, указанному в атрибуте действия формы

Особенности будут зависеть от вашего сервера и выбора языка.

0 голосов
/ 06 января 2012

Единственный известный мне способ использования серверной части javascript - это node.js

...