Что ж, это глобальный вопрос, который требует большого ответа:)
Прежде всего, о вашем вопросе в Twitter, они используют стиль hashbang uri.Например, когда вы переходите на twitter.com / cx42net , вы автоматически перенаправляетесь на twitter.com / #! / Cx42net .
Когда это сканер, напримерGoogle боты, сканер изменит #!
на ?_escaped_fragment=
.Для твиттера это будет выглядеть так: http://twitter.com/?_escaped_fragment=/cx42net.
Я не буду вдаваться в подробности, чтобы избежать ошибок, хорошая ссылка предпочтительнее, поэтому здесь мы идем: SEOMoz: Как: Разрешить Google сканировать ваш AJAX-контент
Теперь для вашего веб-приложения в RESTful мне очень нравится идея отделения клиента от сервера, и я тоже пытаюсь работать таким же образом.
Вы говорите о доступе на основе ролей, что означает, что вам придется идентифицировать своих пользователей, чтобы разрешить / запретить доступ к определенной части вашего API.Существует две школы о том, как аутентифицировать пользователей с помощью API:
- Школа «Использовать базовую аутентификацию HTTP»
- Школа «Использовать аутентификацию / авторизацию OAuth»
Первый вариант очень прост в реализации, но я бы посоветовал вам сделать это через HTTPS, поскольку пароль передается в открытом виде по сети.
Последний вариант хорош, но гораздо сложнее реализовать.
Но на самом деле, это может быть именно то, что вы ищете, потому что, несмотря на аутентификацию вашего пользователя, вы можете предоставить им доступ к определенной части вашего API и ограничить их в какой-то другой части.Типичным примером является то, как Facebook / Twitter работают для этого, и я уверен, что вы уже разрешили сторонним приложениям использовать вашу учетную запись Twitter / Facebook.
Теперь использование OAuth обычно навязывает вам регистрацию/ таблица паролей хранится в вашей базе данных.Вы можете использовать OpenID, но это больше похоже на головную боль, чем на упрощение ваших пользователей: вам нужно аутентифицировать их у провайдера OpenId (например, Google), а затем перенаправить на свой API для предоставления доступа (если это первый раз), ТО перенаправить вашпользователя вашего приложения.
Наконец, я процитирую Фред Уилсон , 10 Золотых принципов успешного веб-приложения :
- Скорость
- Мгновенная утилита
- Меньше значит больше
- Сделайте его программируемым
- Очистите
- ...
Что ж, пока подойдет, если у меня появится другая идея, я отредактирую ответ и добавлю комментарий.