Как в гет запросе в качестве параметра передать url адрес целиком?

Поддержка
  • @uraabk , извиняюсь, нашел ошибку в скрипте гугла. Действительно передается просто без всяких экранирований:

    exec?p1=https://www.aliexpress.com/item/USLION-Phone-Case-For-iPhone-7-6-6s-Plus-5-5s-SE-Simple-Solid-Color-Ultrathin/32808065488.html
    

    А если в ссылке будут русские буквы, с ними как быть?

  • @senerg А что с русскими оно не пропускает? Тогда кодировать. Или заменять русские на английские..

  • @uraabk , да вроде пропускает... и пробелы пропускает, и спецсимволы... А я где-то видео смотрел, что все русское надо кодировать. Ничего не понимаю, но гугл скрипт исправил пока работает.

  • @senerg said in Как в гет запросе в качестве параметра передать url адрес целиком?:

    А я где-то видео смотрел, что все русское надо кодировать.

    так почему бы и не закодировать?

    @senerg что же вы за человек такой?)) Примерно 99% людей сначала 100 раз попробует по разному, потом загуглят и ещё раз 100 попробует и только после этого будут писать где то и спрашивать помощи.
    А вы, увидели, что не отправляется и сразу бежать и спрашивать что но так и почему... а самое главное по подробнее и в деталях)

  • @uraabk, я пытаюсь не столько код написать, сколько изучить возможности баса. Я увидел, что не отправляется, вспомнил, что уже слышал о том, что русские буквы и спецсимволы надо кодировать. Поэтому и решил, не откладывая в долгий ящик разобраться с этим вопросом.
    Гугл скрипт и ява скрипт я тоже толком не знаю, но это не мешает мне нагуглить все, что надо. С басом ситуация другая: документации нет, вот и собираю по крохам информацию, сначала перечитав форум по искомому ключевику, а затем написав тему.

  • @senerg так и что, на всем форуме не нашлось поста с кодирование текста?

  • @uraabk Там прямо скажем не густо. Есть пара ссылок на онлайн сервисы по кодированию, но никакого объяснения что зачем и почему нет.

  • @senerg так тут никто разжевывать не любит. Тут задают вопросы "а как сделать вот это" и получают ответ "вот так" (грубо говоря)
    А для теории и разжевывания существуют специальные обучающие сайты.
    На тоже самое кодирование/декодирование в инете много информации, а как только будет понятно, как это делается, допустим в javascript - то не составит труда сделать это в Басе или составить более грамотный поиск на форуме.

  • Вот сейчас, опять же, идет тема ни о чем... а кто нибудь начнет читать это, в поиске ответа на свой вопрос и в итоге просто потратит время.

  • @uraabk Ну, в целом вы правы. Лично у меня проблемы возникают в основном тогда, когда не до конца понимаешь в чем именно проблема и что конкретно надо загуглить. Плюс тут еще любят через Китай отправить решать то, что решается одной строчкой)

  • @allive Ой, вы как чувствовали))

  • @senerg Для передачи параметров в get-запросе содержащих спецзнаки, используют метод encodeURIComponent(). Сайт для наглядности.

    Ссылки будут выглядеть примерно так:

    exec?p1=https%3A%2F%2Fwww.aliexpress.com%2Fitem%2FUSLION-Phone-Case-For-iPhone-7-6-6s-Plus-5-5s-SE-Simple-Solid-Color-Ultrathin%2F32808065488.html
    

    да вроде пропускает... и пробелы пропускает, и спецсимволы... А я где-то видео смотрел, что все русское надо кодировать. Ничего не понимаю, но гугл скрипт исправил пока работает.

    Попробуйте передать скрипту url с параметрами:

    exec?p1=https://www.google.ru/search?q=site%3Acommunity.bablosoft.com+здесь+могла+бы+быть+ваша+реклама&oq=site%3Acommunity.bablosoft.com+здесь+могла+бы+быть+ваша+реклама
    

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


    Гугл скрипт и ява скрипт я тоже толком не знаю, но это не мешает мне нагуглить все, что надо.

    Значит вопросов о методе encodeURIComponent() мы от вас не увидим?


  • @fox said in Как в гет запросе в качестве параметра передать url адрес целиком?:

    Попробуйте передать скрипту url с параметрами

    Передалось:

    0_1540540934027_fa0aadfd-bc16-4252-8560-63c23ccec0fc-image.png

    Поэтому не понятна вообще цель кодирования.

    @fox said in Как в гет запросе в качестве параметра передать url адрес целиком?:

    Я вам до этого уже говорил, что данные в таблицу лучше передавать post-запросом.

    Можете поделиться ссылкой на пример того как это делается, я с post запросами еще не сталкивался?

    @fox said in Как в гет запросе в качестве параметра передать url адрес целиком?:

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

    Что значит большое количество данных? У меня передается урл, название поста и пара-тройка маленьких переменных. Имеет ли смысл это через пост запросы оформлять?

  • @fox , Нашел все таки что не работает. В строке гет запроса в басе написано это:

    "https://script.google.com/macros/s/.../exec?p1=writeTitle&p2=" + [[URL]] + "&p3=" + [[PIC_A]] + "&p4=" + [[PIC_B]] + "&p5=" + [[TITLE]]
    

    Выбран expression. Все значения переменных в басе определяются правильно. А возвращается это:

    Error 400 (Bad Request)
    

    Когда я беру эту же строчку, вставляю ее в браузер и вручную заменяю переменные, копируя их из баса, то возвращает все как надо "success". Или открываю анализ трафика в бас, проверяю отправленный урл: все правильно. Копирую этот урл из отправленных баса в браузер... Приходит опять "success" и записывается все куда нужно. Оказывается это все из-за пробелов, которые у меня есть в переменной [[TITLE]]. При чем обычный браузер и с пробелами все нормально отрабатывает, а бас с пробелами выдает ошибку 400.

  • @senerg

    При чем обычный браузер и с пробелами все нормально отрабатывает, а бас с пробелами выдает ошибку 400.

    Потому что браузер уже давно экранирует всё автоматом. Но в запросах эта автоматика не нужна, бывают разные ситуации, под которые нужно кодировать строку по разному.

  • @fox Можете поделиться примером с пост запросом?

  • @fox said in Как в гет запросе в качестве параметра передать url адрес целиком?:

    Я вам до этого уже говорил, что данные в таблицу лучше передавать post-запросом

    Записываю вроде как надо:

    https://script.google.com/macros/s/.../
    
    {
      "p1": "writeTitle",
      "p2": [[URL]],
      "p3": [[PIC_A]],
      "p4": [[PIC_B]],
      "p5": [[TITLE]]
    }
    
    application/json
    

    Но все равно не работает, что не так?

  • @senerg POST запросы победил! Всем спасибо.

  • @senerg said in Ошибка с базой данных:

    @cacats знаю только как использовать google sheets для работы с таблицами, базами в БАСе не пользовался.

    Учитывая, что в той теме лично вас не спрашивали и вы не знали ответ на нужный вопрос, значит просто хотели похвастаться :D. Думаю пользователи бы лучше оценили мануал по использованию google sheets в BAS, даже в общих чертах.