NullPointerException
s - исключения, возникающие при попытке использовать ссылку, которая указывает на отсутствие местоположения в памяти (null), как если бы она ссылалась на объект. Вызов метода по нулевой ссылке или попытка получить доступ к полю нулевой ссылки вызовет функцию NullPointerException
. Они наиболее распространены, но другие способы перечислены на странице NullPointerException
javadoc.
Вероятно, самый быстрый пример кода, который я мог бы придумать для иллюстрации NullPointerException
, be:
public class Example {
public static void main(String[] args) {
Object obj = null;
obj.hashCode();
}
}
В первой строке внутри main
я явно устанавливаю ссылку Object
obj
равной null
. Это означает, что у меня есть ссылка, но она не указывает на какой-либо объект. После этого я пытаюсь обработать ссылку так, как если бы она указывала на объект, вызывая метод на нем. Это приводит к NullPointerException
, потому что нет кода для выполнения в местоположении, на которое указывает ссылка.
(Это техничность, но я думаю, что она упоминает: ссылка, которая указывает на null, равна 't то же, что и указатель C, указывающий на недопустимую ячейку памяти. Нулевой указатель буквально не указывает на в любом месте , который отличается от указаний на местоположение, которое оказывается недопустимым.)
Проверьте этот Railscast на OpenId для большего количества информации. Я не уверен, могло ли это работать вместе с restful_authentication, но могло бы быть хорошим ресурсом. (Я еще не наблюдал его)
То, что я сделал, является успокоительной аутентификацией использования, и затем смешайте open_id_authentication плагин в свое приложение. Это могло бы помочь установить open_id_authentication плагин на тестовом приложении также, таким образом, можно определить изменения, необходимо будет сделать к пользовательской таблице.
Категорический ресурс должен быть эти направляющие wiki , хотя я использую , должен намеренно, потому что вещи изменялись довольно быстро когда дело доходит до поддержки OpenID.
Ryan Bates Railscast на Openid является лучшей вещью, которую я нашел для следования. Даже при том, что это было зарегистрировано с направляющими 1.2.3, я был в состоянии успешно следовать учебному руководству с направляющими 2.1.0. Единственный момент, который необходимо отметить, то, что для:
gem install ruby-openid
я установил 2.1.2, а не эти 1.1.4, используемые в railscast.
используемый плагин OpenID является open_id_authentication, и я протестировал его в сочетании с restful_authentication от git://github.com/technoweenie/restful-authentication.git
нбар: Я впоследствии описал это в сообщение в блоге .
Борт теперь имеет включенный OpenID, в дополнение к restful_authentication.
Следите за Борт . Это базовое приложение, которое, помимо прочего, уже имеет настройку restful_authentication. Парень, который делает это, планирует добавить OpenID.
Как ни странно, эта тема, похоже, не привлекала большого внимания сообщества Rails с 2007 года.
Последний ствол Bort, похоже, не работал с Rails 2.3.x, поэтому я разветвил его и заставил работать.
Я также добавил кое-что, что использую лично - например, yui reset / base, jquery и т. д.
Форк все еще находится в стадии разработки, но я надеюсь обеспечить широкую, проверенную поддержку аутентификации для спокойной аутентификации, аутентификации Google, подключения к Facebook, Twitter и т. д.
Я обнаружил, что использование драгоценных камней Authlogic от BinaryLogic довольно просто и понятно. См. Authlogic и его плагин OpenID .
Вы можете загрузить пример приложения или попробовать !