adbrite - jquery $ ajax - PullRequest
       10

adbrite - jquery $ ajax

0 голосов
/ 04 декабря 2011

Так вот что происходит. потому что мой сайт весь jquery / ajax, я думал, что добавить код adbrites на мой сайт будет просто.

Однако происходит следующее

Мне нужно отправить запрос на публикацию на сервер, чтобы получить правильное объявление в этой функции, которую я собираюсь показать, «это дело 90, которое обрабатывает объявление». Однако каждый раз, когда он загружает объявление, он удаляет весь код тела и размещает объявление во всей области тела.

Если вы не знаете, как выглядит код adbrite, он выглядит следующим образом

<!-- Begin: AdBrite, Generated: 2011-12-04 2:47:16  -->
<script type="text/javascript">
var AdBrite_Title_Color = 'CC0000';
var AdBrite_Text_Color = '000000';
var AdBrite_Background_Color = 'FFFFFF';
var AdBrite_Border_Color = 'FFFFFF';
var AdBrite_URL_Color = 'CC0000';
try{var AdBrite_Iframe=window.top!=window.self?2:1;var AdBrite_Referrer=document.referrer==''?document.location:document.referrer;AdBrite_Referrer=encodeURIComponent(AdBrite_Referrer);}catch(e){var AdBrite_Iframe='';var AdBrite_Referrer='';}
</script>
<script type="text/javascript">document.write(String.fromCharCode(60,83,67,82,73,80,84));document.write(' src="http://ads.adbrite.com/mb/text_group.php?sid=2059492&zs=3330305f323530&ifr='+AdBrite_Iframe+'&ref='+AdBrite_Referrer+'" type="text/javascript">');document.write(String.fromCharCode(60,47,83,67,82,73,80,84,62));</script>
<div><a target="_top" href="http://www.adbrite.com/mb/commerce/purchase_form.php?opid=2059492&afsid=55544" style="font-weight:bold;font-family:Arial;font-size:13px;">Your Ad Here</a></div>
<!-- End: AdBrite Ads -->

Вот мой код jQuery.

//send data to server
function fetch(e,formstring)
{
    var a = 1;
    $.ajax({
      type: 'POST',
      url: 'system/engine/core.php',
      data: formstring,
      dataType: 'json',
      contentType: "application/x-www-form-urlencoded;charset=utf-8",
      beforeSend: function() {
                switch (e) {
                 case 2:
                 $("#content").html(" <div id='advertarea'></div>");
                 break;
                 case 400:
                 $('#searchresultssmall').html(" ");
                 break;
                }
            },
      success: function(data){
        $.each(data, function(i, obj) {

               switch (e) { 
                 case 1:
                 //Menu
                 links = obj.name.replace(/\s+/g, '-').toLowerCase();
                 $("ul#menu").append('<a href="/'+links+'"><li class="active">'
                                   +obj.name
                                   +'<li><a>');

                 break;
                 case 2:
                  links = obj.name.replace(/\s+/g, '-').toLowerCase();
                  $("#content").append('<a href="/'+links+'"><img class="catimages" src="'
                                   +obj.picture
                               +'"/><a>');
                 //$("#content").html("hello");
                 break;
                 case 3:
                 $.each(obj, function(key, val) {
                     if(val != 0)
                     {
                        $("#usernametaken").html("<span style='color:red'><b>"+username+"</b> - is taken");  
                        unamecheck = 0;
                     }
                     else
                     {
                        $("#usernametaken").html('<img src="theme/sysimages/tick.png"/><span style=" color: white;"><b>'+username+'</b> is valid</span');
                        unamecheck = 1;
                     }
                     unamecheck = val;
                  });
                 break; 
                 case 4:
                 //LoginSript

                    $('#rightheader').html(obj.code);
                 break;
                 //advertismentarea
                 case 90:
                 $("#advertarea").html(""+obj.code+"");
                 break;
               }
             });
      },
      error: function(data){
      $.each(data,function(i,myinfo){
            //alert(i);     
          });
      },
      complete: function(){
        //shownotify(2,"");  
      },
      "text json": jQuery.parseJSON
    });
    return false;
}

1 Ответ

0 голосов
/ 04 декабря 2011

В коде Adbrite используется функция document.write js ..., которая должна вызываться только во время загрузки документа. Если вы сделаете это после, он очистит документ, а затем напишет новый контент (объявление)

Замените document.write и jquery append вместо этого.

REPLACE

<script type="text/javascript">document.write(String.fromCharCode(60,83,67,82,73,80,84));document.write(' src="http://ads.adbrite.com/mb/text_group.php?sid=2059492&zs=3330305f323530&ifr='+AdBrite_Iframe+'&ref='+AdBrite_Referrer+'" type="text/javascript">');document.write(String.fromCharCode(60,47,83,67,82,73,80,84,62));</script>

с этим,

<script type="text/javascript">$('body').append( String.fromCharCode(60,83,67,82,73,80,84) + ' src="http://ads.adbrite.com/mb/text_group.php?sid=2059492&zs=3330305f323530&ifr='+AdBrite_Iframe+'&ref='+AdBrite_Referrer+'" type="text/javascript">' + String.fromCharCode(60,47,83,67,82,73,80,84,62) );</script>

Если вы не хотите / не можете изменить рекламный код, подайте его в другом iframe

...