Я пытаюсь создать букмарклет для публикации закладок del.icio.us в отдельную учетную запись.
Я тестировал это из командной строки, например:
wget -O - --no-check-certificate \
"https://seconduser:[email protected]/v1/posts/add?url=http://seet.dk&description=test"
Это прекрасно работает.
Затем я хотел создать букмарклет в своем Firefox. Я погуглил и нашел кусочки и кусочки и в итоге получил:
javascript:void(
open('https://seconduser:[email protected]/v1/posts/add?url='
+encodeURIComponent(location.href)
+'&description='+encodeURIComponent(document.title),
'delicious','toolbar=no,width=500,height=250'
)
);
Но все, что происходит, я получаю от del.icio.us:
<?xml version = "1.0" standalone = "yes"?>
<result code = "access denied" />
<!-- fe04.api.del.ac4.yahoo.net uncompressed/chunked Thu Aug 7 02:02:54 PDT 2008 -->
Если я затем перейду в адресную строку и нажму Enter, она изменится на:
<?xml version='1.0' standalone='yes'?>
<result code = "done" />
<!-- fe02.api.del.ac4.yahoo.net uncompressed/chunked Thu Aug 7 02:07:45 PDT 2008 -->
Есть идеи, как заставить его работать прямо из закладок?



![Безумие обратных вызовов в javascript [JS]](https://i.imgur.com/WsjO6zJb.png)


Работает ли вызов метода дважды?
Мне кажется, что ваша аутентификация утверждается после поступления контента, поэтому теперь работает вторая попытка, потому что у вас есть правильные файлы cookie.
Можете ли вы проанализировать трафик, чтобы узнать, что на самом деле отправляется? Отправляет ли он какие-либо данные аутентификации, и они неверны, или представлены в форме, которая не нравится серверу, или они вообще никогда не отправляются через firefox?
Я бы рекомендовал проверить Дополнение iMacros для Firefox. Я использую его для входа на локальный веб-сервер и после входа в систему, перехожу прямо на определенную страницу. Код, который у меня есть, выглядит так, но он позволяет вам записывать свои собственные макросы:
VERSION BUILD=6000814 RECORDER=FX
TAB T=1
URL GOTO=http://10.20.2.4/login
TAG POS=1 TYPE=INPUT:TEXT FORM=NAME:introduce ATTR=NAME:initials CONTENT=username-goes-here
SET !ENCRYPTION NO
TAG POS=1 TYPE=INPUT:PASSWORD FORM=NAME:introduce ATTR=NAME:password CONTENT=password-goes-here
TAG POS=1 TYPE=INPUT:SUBMIT FORM=NAME:introduce ATTR=NAME:Submit&&VALUE:Go
URL GOTO=http://10.20.2.4/timecard
Я щелкаю по нему средней кнопкой, и он открывает новую вкладку и запускает макрос, который переводит меня прямо на нужную страницу, вошел в систему с указанной мной учетной записью.
@travis Выглядит очень красиво! Я обязательно посмотрю на это. Я могу придумать несколько мест, где я могу использовать это
Мне так и не удалось обнюхать трафик, но я обнаружил, что php-сайт на моем собственном сервере с http-auth работает нормально, поэтому я подумал, что это что-то вкусное. Затем я создал страницу php, которая делает wget из восхитительного api, и все работает нормально :)