Как сделать кнопки PayPal «Обязательными»? - PullRequest
2 голосов
/ 20 ноября 2011

Я создал кнопку оплаты сейчас, используя генератор кнопок PayPal.

Кнопка имеет 2 поля, а затем вы нажимаете кнопку оплаты сейчас.

Однако, если вы оставите эти поля пустыми, выЯ все еще могу заплатить

Я хочу сделать эти поля "обязательными", если пользователь не заполнил эти поля, он не сможет платить.Как?

Кнопка не размещена на PayPal, но защита кнопки ON .Я хочу, чтобы кнопка была зашифрована.

РЕДАКТИРОВАТЬ

Я попытался проверить форму javascript, не сработало, не помогло?

вот скрипт

<form
action="https://www.paypal.com/cgi-bin/webscr" method="post">
<input type="hidden" name="cmd" value="_s-xclick">
<table>
<tr><td><input type="hidden" name="on0" value="first form">form 1</td></tr><tr><td><input type="text" name="os0" maxlength="200"></td></tr>
<tr><td><input type="hidden" name="on1" value="2nd form">2nd form</td></tr><tr><td><input type="text" name="os1" maxlength="200"></td></tr>
</table>
<input type="hidden" name="encrypted" value=" encryption here ">
<input type="image" src="https://www.paypalobjects.com/en_US/i/btn/btn_paynowCC_LG.gif" border="0" name="submit" alt="PayPal - The safer, easier way to pay online!">
<img alt="" border="0" src="https://www.paypalobjects.com/en_US/i/scr/pixel.gif" width="1" height="1">
</form>

любая помощь в заполнении этих полей?Я дам вам 3 голоса "за", потому что у меня есть 3 аккаунта на стеке и принятый ответ - это самое малое, что я могу сделать:)

PS

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

ОБНОВЛЕНИЕ - @Last Rose Studios

Я перепробовал много способов проверки, наконец, я использовал проверку контактной формы моего друга lol

validation.js

function has_id(id){try{var tmp=document.getElementById(id).value;}catch(e){return false;}
return true;}
function has_name(nm){try{var tmp=cfrm.nm.type;}catch(e){return false;}
return true;}
function $$(id){if(!has_id(id)&&!has_name(id)){alert("Field "+id+" does not exist!\n Form validation configuration error.");return false;}
if(has_id(id)){return document.getElementById(id).value;}else{return;}}
function $val(id){return document.getElementById(id);}
function trim(id){$val(id).value=$val(id).value.replace(/^\s+/,'').replace(/\s+$/,'');}
var required={field:[],add:function(name,type,mess){this.field[this.field.length]=[name,type,mess];},out:function(){return this.field;},clear:function(){this.field=[];}};var validate={check:function(cform){var error_message='Please fix the following errors:\n\n';var mess_part='';var to_focus='';var tmp=true;for(var i=0;i<required.field.length;i++){if(this.checkit(required.field[i][0],required.field[i][1],cform)){}else{error_message=error_message+required.field[i][2]+' must be supplied\n';if(has_id(required.field[i][0])&&to_focus.length===0){to_focus=required.field[i][0];}
tmp=false;}}
if(!tmp){alert(error_message);}
if(to_focus.length>0){document.getElementById(to_focus).focus();}
return tmp;},checkit:function(cvalue,ctype,cform){if(ctype=="NOT_EMPTY"){if(this.trim($$(cvalue)).length<1){return false;}else{return true;}}else if(ctype=="EMAIL"){exp=/^[a-zA-Z0-9._%-]+@[a-zA-Z0-9.-]+\.[a-zA-Z]{2,4}$/;if($$(cvalue).match(exp)==null){return false;}else{return true;}}},trim:function(s){if(s.length>0){return s.replace(/^\s+/,'').replace(/\s+$/,'');}else{return s;}}};

paypal.html

<script src="validation.js"></script>


    <script>
    required.add('os0','NOT_EMPTY','1st form');

    required.add('os1','NOT_EMPTY','2nd form')

    </script>


<form action="https://www.paypal.com/cgi-bin/webscr" method="post" onsubmit="return validate.check(this)">
<input type="hidden" name="cmd" value="_s-xclick">
<table>
<tr><td><input type="hidden" name="on0" value="1st form">1st form<span class="required_star"> * </span></td></tr><tr><td><input type="text" name="os0" maxlength="200" id="os0" class="required"></td></tr>
<tr><td><input type="hidden" name="on1" value="2nd form">2nd form<span class="required_star"> * </span></td></tr><tr><td><input type="text" id="os1" name="os1" maxlength="200" class="required"></td></tr>
</table>
<input type="hidden" name="encrypted" value=" encryption here
">
<input type="image" src="https://www.paypalobjects.com/en_US/i/btn/btn_paynowCC_LG.gif" border="0" name="submit" alt="PayPal - The safer, easier way to pay online!">
<img alt="" border="0" src="https://www.paypalobjects.com/en_US/i/scr/pixel.gif" width="1" height="1">
</form>

Я использовал JavaScript, а затем прочитал ваш ответ, но я не собираюсь менять его, потому что он работает сейчас

У меня еще есть 2 небольших вопроса

1 - можно ли удалить окно описания со страницы PayPal, см. enter image description here

2 - PayPal не перенаправляет на страницу благодарности после оплаты, я создал много кнопок, этопросто не перенаправляю (у меня нет страницы отмены)

Ответы [ 2 ]

7 голосов
/ 26 ноября 2011

вы можете использовать входной атрибут html5 'required', и это позаботится о некоторых браузерах, для других вам придется использовать javascript для проверки формы.

Я буду использовать jQuery, если выне стесняйтесь привести вам короткий пример.

$('form').submit(function(e){
    flag = false;
    $('[name="os0"], [name="os1"]').css('background','').each(function(){
        el=$(this);
        if(el.val().length == 0){
           flag = true;
           el.css('background','red');
        }
    });
    if(flag){
     return false;
    }
});

это предотвратит отправку формы, если не заполнены оба поля.Я также добавил некоторую обратную связь для пользователя, повернув фон ввода красного цвета (необязательно).

Конечно, это будет работать только в современных браузерах или старых браузерах с включенным javascript, но все равно будет небольшой процент, гдеэто пройдет.В этом случае предложение Роберта о публикации на промежуточной странице на вашем сервере может быть хорошей идеей.

3 голосов
/ 21 ноября 2011

Без изменения кода кнопки вам потребуется решение на стороне клиента (как вы упомянули), так как POST будет напрямую переходить на PayPal (https://www.paypal.com/cgi-bin/webscr).
Кроме того, вы можете отправить POST на промежуточную страницу на вашем сервере и переслать туда от PayPal, чтобы включить проверку на стороне сервера (только если поля абсолютно обязательны, например, в случае отключения JavaScript, например). ).

...