Программирование на языке Ruby
Шрифт:
В классе
PGconn
определены также следующие полезные методы: •
db
возвращает имя базы, с которой установлено соединение; •
host
возвращает имя сервера, с которым установлено соединение; •
user
возвращает имя аутентифицированного пользователя; •
error
возвращает сообщение об ошибке; •
finish
, close
закрывают соединение; •
loimport(file)
импортирует файл в большой двоичный объект (BLOB), в случае успеха возвращает объект PGlarge
,
PGError
; •
loexport(oid, file)
выгружает BLOB с идентификатор oid
в указанный файл; •
locreate([mode])
возвращает объект PGlarge
в случае успеха, иначе возбуждает исключение PGError
; •
loopen(oid, [mode])
открывает BLOB с идентификатором oid
. Возвращает объект PGlarge
в случае успеха. Аргумент mode
задает режим работы с открытым объектом: "INV_READ"
или "INV_WRITE"
(если этот аргумент опущен, по умолчанию предполагается "INV_READ"
); •
lounlink(oid)
удаляет BLOB с идентификатором oid
. Отметим, что пять последних методов (
loimport
, loexport
, locreate
, loopen
и lounlink
) работают с объектами класса PGlarge
. У этого класса есть собственные методы для доступа к объекту и его изменения. (BLOB'ы создаются в результате выполнения методов loimport
, locreate
, loopen
экземпляра.) Ниже перечислены методы, определенные в классе
PGlarge
: •
open([mode])
открывает BLOB. Аргумент mode
задает режим работы с объектом, как и в случае с методом PGconn#loopen
); •
close
закрывает BLOB (BLOB'ы также закрываются автоматически, когда их обнаруживает сборщик мусора); •
read([length])
пытается прочитать length
байтов из BLOB'a. Если параметр length
не задан, читаются все данные; •
write(str)
записывает строку в BLOB и возвращает число записанных байтов; •
tell
возвращает текущую позицию указателя; •
seek(offset, whence)
перемещает указатель в позицию offset
. Параметр whence
может принимать значения SEEK_SET
, SEEK_CUR
и SEEK_END
(равные соответственно 0,1,2); •
unlink
удаляет BLOB; •
oid
возвращает идентификатор BLOB'a; •
size
возвращает размер BLOB'a; •
export(file)
сохраняет BLOB в файле с указанным именем. Более интересны методы экземпляра, определенные в классе
PGresult
(перечислены ниже). Объект такого класса возвращается в результате успешного выполнения запроса. (Для экономии памяти вызывайте метод PGresult#clear
по завершении работы с таким объектом.) •
result
возвращает массив кортежей, описывающих результат запроса; •
each
—
итератор; •
[]
— метод доступа; •
fields
возвращает массив описаний полей результата запроса; •
num_tuples
возвращает число кортежей в результате запроса; •
fieldnum(name)
возвращает индекс поля с указанным именем; •
type(index)
возвращает целое число, соответствующее типу поля; •
size(index)
возвращает размер поля в байтах. 1 означает, что поле имеет переменную длину; •
getvalue(tup_num, field_num)
возвращает значение поля с указанным порядковым номером; tup_num
— номер строки; •
getlength(tup_num, field_num)
возвращает длину поля в байтах; •
cmdstatus
возвращает строку состояния для последнего запроса; •
clear
очищает объект PGresult
. 10.4.4. Интерфейс с LDAP
Для Ruby есть по меньшей мере три разных библиотеки, позволяющих работать с протоколом LDAP. Ruby/LDAP, написанная Такааки Татеиси (Takaaki Tateishi), — это довольно «тонкая» обертка. Если вы хорошо знакомы с LDAP, то ее может оказаться достаточно; в противном случае вы, наверное, сочтете ее слишком сложной. Пример:
conn = LDAP::Conn.new("rsads02.foo.com")
conn.bind("CN=username,CN=Users,DC=foo,DC=com", "password") do |bound|
bound.search("DC=foo,DC=com", LDAP::LDAP_SCOPE_SUBTREE,
"(&(name=*) (objectCategory=person))", ['name','ipPhone'])
do |user|
puts "#{user['name']} #{user['ipPhone']}"
end
end
Библиотека
ActiveLDAP
организована по образцу ActiveRecord
. Вот пример ее использования, взятый с домашней страницы:
require 'activeldap'
require 'examples/objects/user'
require 'password'
# Установить соединение Ruby/ActiveLDAP и т. д.
ActiveLDAP::Base.connect(:password_block
=> Proc.new { Password.get('Password: ') },
:allow_anonymous => false)
# Загрузить запись с данными о пользователе
# (ее класс определен в примерах).
wad = User.new('wad')
# Напечатать общее имя.
р wad.cn
# Изменить общее имя.
wad.cn = "Will"
# Сохранить в LDAP.
wad.write
Есть также сравнительно недавняя библиотека, написанная Фрэнсисом Чианфрокка (Francis Cianfrocca), многие предпочитают именно ее:
require 'net/ldap'
ldap = Net::LDAP.new :host => server_ip_address,
Поделиться с друзьями: