You can’t access details of the exception if the channel is disposed. So the lovely using
pattern construction is not recommended when accessing a WCF service. In fact, the Exception properties requires to have access to the channel to extract some information about the exception (don’t know if MS missed that point, or if there are technical reasons behind).
I’ve written a small class to simplify the call to WCF proxies (this site helps me to understand the problem and to write the class) :
using System;
using System.ServiceModel;
namespace Utility
{
public class ServiceHelper
{
/// <summary>
/// WCF proxys do not clean up properly if they throw an exception. This method ensures that the service
/// proxy is handeled correctly. Do not call TService.Close() or TService.Abort() within the action lambda.
/// </summary>
/// <typeparam name="TService">The type of the service to use</typeparam>
/// <param name="action">Lambda of the action to performwith the service</param>
[System.Diagnostics.DebuggerStepThrough]
public static void UsingProxy<TService>(Action<TService> action)
where TService : ICommunicationObject, IDisposable, new()
{
var service = new TService();
bool success = false;
try
{
action(service);
if (service.State != CommunicationState.Faulted)
{
service.Close();
success = true;
}
}
finally
{
if (!success)
{
service.Abort();
}
}
}
/// <summary>
/// WCF proxys do not clean up properly if they throw an exception. This method ensures that the service
/// proxy is handeled correctly. Do not call TService.Close() or TService.Abort() within the action lambda.
/// </summary>
/// <typeparam name="TIServiceContract">The type of the service contract to use</typeparam>
/// <param name="action">Action to perform with the client instance.</param>
/// <remarks>In the configuration, an endpoint with names that maches the <typeparamref name="TIServiceContract"/> name
/// must exists. Otherwise, use <see cref="UsingContract<TIServiceContract>(string endpointName, Action<TIServiceContract> action)"/>. </remarks>
[System.Diagnostics.DebuggerStepThrough]
public static void UsingContract<TIServiceContract>(Action<TIServiceContract> action)
{
UsingContract<TIServiceContract>(
typeof(TIServiceContract).Name,
action
);
}
/// <summary>
/// WCF proxys do not clean up properly if they throw an exception. This method ensures that the service
/// proxy is handeled correctly. Do not call TService.Close() or TService.Abort() within the action lambda.
/// </summary>
/// <typeparam name="TIServiceContract">The type of the service contract to use</typeparam>
/// <param name="action">Action to perform with the client instance.</param>
/// <param name="endpointName">Name of the endpoint to use</param>
[System.Diagnostics.DebuggerStepThrough]
public static void UsingContract<TIServiceContract>(
string endpointName,
Action<TIServiceContract> action)
{
var cf = new ChannelFactory<TIServiceContract>(endpointName);
var channel = cf.CreateChannel();
var clientChannel = (IClientChannel)channel;
bool success = false;
try
{
action(channel);
if (clientChannel.State != CommunicationState.Faulted)
{
clientChannel.Close();
success = true;
}
}
finally
{
if (!success) clientChannel.Abort();
}
}
}
}
Then you can simply do something like this (depending if you have a service reference or the contracts :
ServiceHelper.UsingContract<IFxCurveService>(svc=>
{
guid = svc.ReserveSnapshot(fxCurveKey);
DiscountFactorNew[] dfs = svc.GetDiscountFactors(guid, dates, from));
Assert.IsTrue(guid != null);
}),
This helpers ensure the correct closing of channels, whithout disposing it. You will be able to see the actual exception then. Edit your post when you’ll find the actual exception.
(Maybe your service factory is already using this technique. If not, do not hesitate to update it like my class).
[edit] You still have to play with config. here is a probably working config for you :
contract="The.Correct.Namespace.IFxCurveService"
name="IFxCurveService" />
В вкратце суть проблемы: есть веб-сервис из внешней системы. Там реализован метод с входным параметром и при вызове этого метода возникает ошибка: «Ошибка преобразования данных XDTO. Структура объекта не соответствует типу». Веб-сервис с которым возникает проблема реализован на стороне SAP. До этого я работала с аналогичными веб-сервисами реализованными на Java и никогда таких проблем не возникало. Не понимаю в чем дело, может быть кто-то сталкивался с подобным.
Вот сохраненная wsdl данного сервиса: http://rusfolder.com/34890963
А теперь по порядку, как и что, делаю:
1. Веб-сервис добавлен в конфигуратор в WS-ссылки.
2. Подключаю веб-сервис следующим образом
Процедура ПодключитьВебСервис()
ИмяСервиса=»z_service»;
ИмяПортаСервиса=»z_service_bind»;
ПространствоИмен=»urn:sap-com:document:sap:soap:functions:mc-style»;
ВебСервис=WSСсылки.WSintegrationSAP.СоздатьWSПрокси(ПространствоИмен,ИмяСервиса,ИмяПортаСервиса);
КонецПроцедуры
3. Затем заполняю входной параметр для вызываемого метода
Функция ВходнойПараметр()
ТипTableOfZmaraTab = ВебСервис.ФабрикаXDTO.Тип(ПространствоИмен, «TableOfZmaraTab»);
TableOfZmaraTab = ВебСервис.ФабрикаXDTO.Создать(ТипTableOfZmaraTab);
ТипZmaraTab = ВебСервис.ФабрикаXDTO.Тип(ПространствоИмен, «ZmaraTab»);
ZmaraTab = ВебСервис.ФабрикаXDTO.Создать(ТипZmaraTab);
ТипChar18 = ВебСервис.ФабрикаXDTO.Тип(ПространствоИмен, «char18»);
ТипChar18 = ВебСервис.ФабрикаXDTO.Тип(ПространствоИмен, «char18»);
ТипChar2 = ВебСервис.ФабрикаXDTO.Тип(ПространствоИмен, «char2»);
ТипChar40 = ВебСервис.ФабрикаXDTO.Тип(ПространствоИмен, «char40»);
ТипChar4000= ВебСервис.ФабрикаXDTO.Тип(ПространствоИмен, «char4000»);
ТипChar9 = ВебСервис.ФабрикаXDTO.Тип(ПространствоИмен, «char9»);
ТипUnit3 = ВебСервис.ФабрикаXDTO.Тип(ПространствоИмен, «unit3»);
ZmaraTab.Matnr = ВебСервис.ФабрикаXDTO.Создать(ТипChar18, «Код»);
ZmaraTab.Maktx = ВебСервис.ФабрикаXDTO.Создать(ТипChar40, «Наименование»);
ZmaraTab.Ferth = ВебСервис.ФабрикаXDTO.Создать(ТипChar18, «Марка»);
ZmaraTab.Meins = ВебСервис.ФабрикаXDTO.Создать(ТипUnit3, «Ед.»);
ZmaraTab.Matkl = ВебСервис.ФабрикаXDTO.Создать(ТипChar9, «Группа»);
ZmaraTab.Attyp = ВебСервис.ФабрикаXDTO.Создать(ТипChar2, «Тп»);
ZmaraTab.Lname = ВебСервис.ФабрикаXDTO.Создать(ТипChar4000,»Полное наименование»);
TableOfZmaraTab.item.Add(ZmaraTab);
Возврат TableOfZmaraTab;
КонецФункции
4. Затем вызываю метод с входным параметром
Процедура ПолучитьДанные()
ПодключитьВебСервис();
ВхПараметр = ВходнойПараметр();
РезультатСервиса = ВебСервис.ZMatnrKug(ВхПараметр);
КонецПроцедуры
5. В момент обращения к методу возникает вот такая ошибка
Ошибка при вызове метода контекста (ZMatnrKug): Ошибка вызова операции сервиса: {urn:sap-com:document:sap:soap:functions:mc-style}:z_service:ZMatnrKug() РезультатСервиса = ВебСервис.ZMatnrKug(ВхПараметр);
по причине:
Ошибка вызова операции сервиса: {urn:sap-com:document:sap:soap:functions:mc-style}:z_service:ZMatnrKug()
по причине:
Неизвестная ошибка. Ошибка преобразования данных XDTO:
Чтение объекта типа: {urn:sap-com:document:sap:soap:functions:mc-style}TableOfZmaraTab — [1,227]
Проверка дополнительного свойства:
форма: Элемент
имя: item
по причине:
Ошибка преобразования данных XDTO:
Чтение объекта типа: {urn:sap-com:document:sap:soap:functions:mc-style}TableOfZmaraTab — [1,227]
Проверка дополнительного свойства:
форма: Элемент
имя: item
по причине:
Ошибка проверки данных XDTO:
Структура объекта не соответствует типу: {urn:sap-com:document:sap:soap:functions:mc-style}TableOfZmaraTab
В платформе 1С сообщения об ошибках бывают достаточно запутаны, и без должных навыков разобраться в причинах достаточно сложно. Вот и сообщение об ошибке при вызове контекста может ввести в ступор начинающего разработчика. Однако в подавляющем большинстве случаев мы видим подобное сообщение, если разработчик допустил ошибку в своем коде. Причем речь зачастую идет не об орфографических ошибках, а о логических.
Исправляем ситуацию
Чтобы избавиться от этого неприятного сообщения об ошибке при вызове метода контекста, следует понимать, что контекстом называют методы платформы 1С. Значит в определенной строке кода воспользовались методом с неверными параметрами или вызвали его не от того владельца. Всегда внимательно и полностью читайте сообщения об ошибках – часто в них содержится указание на строку и метод, вызвавший ошибку. Это поможет сэкономить время на отладку и поиск проблемного места в коде.
Рассмотрим действия разработчика на примере со специально допущенной ошибкой. Мы запускаем на исполнение нижеприведенный кусок кода с запросом, в котором забыли дописать условие отбора. Компилятор 1С пропускает такую процедуру, так как орфографических ошибок в написании команд мы не допустили. Однако в режиме предприятия нас ждет такое сообщение об ошибке:
Запрос = Новый Запрос;
Запрос.Текст =
"ВЫБРАТЬ
| Номенклатура.Ссылка КАК Ссылка,
| Номенклатура.ВерсияДанных КАК ВерсияДанных,
| Номенклатура.ПометкаУдаления КАК ПометкаУдаления,
| Номенклатура.Родитель КАК Родитель,
| Номенклатура.ЭтоГруппа КАК ЭтоГруппа,
| Номенклатура.Код КАК Код,
| Номенклатура.Наименование КАК Наименование,
| Номенклатура.Артикул КАК Артикул,
| Номенклатура.ЕдиницаИзмерения КАК ЕдиницаИзмерения,
| Номенклатура.ТипНоменклатуры КАК ТипНоменклатуры,
| Номенклатура.Предопределенный КАК Предопределенный,
| Номенклатура.ИмяПредопределенныхДанных КАК ИмяПредопределенныхДанных
|ИЗ
| Справочник.Номенклатура КАК Номенклатура
|ГДЕ
| ";
РезультатЗапроса = Запрос.Выполнить();
ВыборкаДетальныеЗаписи = РезультатЗапроса.Выбрать();
Пока ВыборкаДетальныеЗаписи.Следующий() Цикл
КонецЦикла;
Приведенный текст ошибки программисту 1С скажет, что в модуле формы обработки «ЧтениеЗаписьXML на 152 строчке кода не может выполниться запрос. Причина в том, что на 17 строчке запроса нет чего-то, что ждал компилятор. Таким образом, чтобы убрать подобное сообщение, необходимо выяснить, что там должно быть и написать недостающий код.
Увидев вышеприведенный кусок кода, разработчик заметит, что в запросе есть служебное слово «ГДЕ», дающее сигнал 1С, что дальше будет условие. Но мы забыли дописать его и, естественно, система с помощью сообщения об ошибке спрашивает нас – «а где условие?». Чтобы исправить эту ситуацию необходимо либо убрать оператор «ГДЕ» из запроса, либо добавить условие.
Но ошибки могут быть не только в текстах запросов. Допустим, мы хотим выбрать всю номенклатуру и узнать, входит ли она в определенную группу. Проверка происходит с помощью метода «ПринадлежитЭлементу» и его параметра, который должен быть типа СправочникСсылка. Мы опять допускаем ошибку и вместо ссылки в параметр метода помещаем строку, содержащую имя переменной.
Запрос = Новый Запрос;
Запрос.Текст =
"ВЫБРАТЬ
| Номенклатура.Ссылка КАК Ссылка,
| Номенклатура.ВерсияДанных КАК ВерсияДанных,
| Номенклатура.ПометкаУдаления КАК ПометкаУдаления,
| Номенклатура.Родитель КАК Родитель,
| Номенклатура.ЭтоГруппа КАК ЭтоГруппа,
| Номенклатура.Код КАК Код,
| Номенклатура.Наименование КАК Наименование,
| Номенклатура.Артикул КАК Артикул,
| Номенклатура.ЕдиницаИзмерения КАК ЕдиницаИзмерения,
| Номенклатура.ТипНоменклатуры КАК ТипНоменклатуры,
| Номенклатура.Предопределенный КАК Предопределенный,
| Номенклатура.ИмяПредопределенныхДанных КАК ИмяПредопределенныхДанных
|ИЗ
| Справочник.Номенклатура КАК Номенклатура
|ГДЕ
| НЕ Номенклатура.ЭтоГруппа ";
НужнаяГруппаЭлементов = Справочники.Номенклатура.НайтиПоНаименованию("Мебель");
РезультатЗапроса = Запрос.Выполнить();
ВыборкаДетальныеЗаписи = РезультатЗапроса.Выбрать();
Пока ВыборкаДетальныеЗаписи.Следующий() Цикл
Сообщить(ВыборкаДетальныеЗаписи.Ссылка.ПринадлежитЭлементу("НужнаяГруппаЭлементов"));
КонецЦикла;
1С выдает настолько же информативное сообщение, из которого мы понимаем, что на 158 строке у 1 параметра неправильный тип. Но что же делать, если мы не знаем, какой тип должен быть? В этом нам поможет Синтакс-помощник, встроенный в платформу 1С.
В конфигураторе находим строку и метод, на который указывало сообщение об ошибке, и нажимаем на него правой кнопкой мыши. Выбираем пункт «Поиск в синтакс-помощнике» и платформа самостоятельно ищет справочную информацию по выделенному методу. В справке мы видим не только подробное описание параметров и самого метода, но и пример. Сверив пример с нашим кодом, приходит понимание, что кавычки не нужны и без них все работает.
Чаще всего причиной подобных ошибок выступают следующие факторы:
- Невнимательность;
- Отсутствие опыта или знаний;
- Несогласованность действий разработчиков друг с другом;
- Изменения в методах контекста в новых версиях платформы.
Но ошибки при разработке ПО случаются постоянно, поскольку иногда ошибаются даже специалисты с многолетним опытом. Самое главное – уметь исправлять их и учиться на них. Постепенно вы будете видеть сообщения об ошибках все реже и научитесь замечать подобные «опечатки» еще до запуска 1С.
Довольно часто начинающие 1С разработчики сталкиваются с ошибками, которых достаточно легко избежать. Ниже мы рассмотрим топ 11 ошибок и способы их исправления. Также доступна видеоверсия статьи
Содержание
Поле объекта не обнаружено
Существует множество статей, которые описывают возможные причины возникновения в 1С ошибки “Поле объекта не обнаружено”. Порой это связывают с обновлением платформы, обновлением типового релиза, или с какими-то другими причинами.
Мы же будем оперировать фактами. В конце статьи прилагается внешняя обработка, в которой воспроизведена данная ошибка.
Такое сообщение платформа выдает, когда пытается обратиться к свойству объекта языка, которого у данного объекта нет. Не важно, что это за объект – документ, справочник, таблица значений , или сообщение пользователю.
- Удалили табличную часть, к которой обращаемся в коде?
- Переименовали реквизит, а в коде не исправили?
- Заменили значение со ссылки на неопределено?
Вуаля – платформа выдаст ошибку “Поле объекта не обнаружено”!
Как исправить? Исходя из природы ошибки – переименовать реквизит на нужное имя, отредактировать код, или использовать правильные обращения к стандартным свойствам объекта.
Например, у объекта “СообщениеПользователю” нет свойства “Таблица”, и следующий код приведет к ошибке:
Сообщение = Новый СообщениеПользователю;
Сообщение.Таблица = “Ошибка”;
Индекс находится за границами массива
Что означает такое сообщение системы? Как правило, с данной ошибкой разработчик сталкивается при некорректной работе с коллекциями. Самые частые случаи появления ошибки “Индекс находится за границами массива”.
- Использование при обходе коллекции количества элементов вместо индекса. Индексы начинаются с нуля, а количество элементов – с единицы. Поэтому следующий код гарантированно приведет к ошибке: Массив[Массив.Количество()]
- Последствия удаления элементов из коллекции, очистки коллекции или замены коллекции на пустую
- Ошибочное увеличение счетчика в цикле “Для”
Как исправить? Для удаления элементов из коллекции по условию – использовать обратный цикл. Добавлять условие на соответствие счетчика цикла и индекса массива. Не увеличивать счетчик внутри кода цикла Для … Цикл … КонецЦикла
Обращение к процедуре как к функции
Суть этой ошибки в том, что процедура не может возвращать значение. И если мы в коде используем вызов процедуры справа от знака присваивания, это приведет к ошибке.
Данная ошибка имеет две вариации – если используется стандартная процедура из методов какого-нибудь объекта, то фраза будет звучать “Обращение к процедуре объекта как к функции”. Если же использовать процедуру, объявленную в коде, то текст ошибки будет “Обращение к процедуре как к функции”.
При этом ошибка использования процедуры объекта является ошибкой времени выполнения – т.е. на этапе сохранения и проверки конфигурации платформа эту ошибку не обнаружит.
А вот неправильное использование процедуры синтаксическая проверка (Ctrl + F7) успешно обнаруживает, и не даст сохранить конфигурацию или внешнюю обработку/отчет, пока ошибка не будет устранена.
Рассмотрим два примера:
1. Воспроизведем ошибку “Обращение к процедуре как к функции”. При этом платформа не даст сохранить изменения, т.к. не проходит синтакс-контроль.
2. Воспроизведем ошибку “Обращение к процедуре объекта как к функции”. Здесь мы неверно используем метод объекта массива “Добавить”, который является процедурой.
Как исправить? Ошибка тривиальная, и исправление тоже. Чаще всего, достаточно внимательно прочитать описание методов объекта во встроенной справке или синтакс-помощнике. Если метод является процедурой, то значений он возвращать не может. Следовательно, нужно модифицировать код так, чтобы такого ошибочного вызова не было.
Если же используется процедура, объявленная в коде, возможно, есть необходимость изменить ее на функцию, либо также скорректировать код, который эту процедуру использует.
Процедура не может возвращать значение
Родственная предыдущей ошибка. Для того, чтобы код возвращал какое-то значение, следует этот код размещать в функции, а не в процедуре.
В процедуре можно написать ключевое слово “Возврат” без параметров. Это будет означать выход из процедуры.
Следующий код является ошибочным, т.к. в теле процедуры Возврат используется с параметром:
Процедура ПроцедураНеМожетВозвращатьЗначение(Команда) Возврат "Ошибка"; КонецПроцедуры
Как исправить? Платформа сама подсказывает, в каком месте кода ошибка. Нужно изменить текст модуля – либо удалить параметр у ключевого слова Возврат, либо убрать его вовсе, либо изменить процедуру на функцию – зависит от того, какая логика у вашей процедуры, и как вы предполагаете ее использовать.
Переменная не определена
Такой текст ошибки платформа 1С выдает на этапе синтаксического контроля, при сохранении конфигурации, внешнего отчета или обработки.
Причин у этой ошибки может быть несколько.
- Опечатка в имени переменной
- Обращение к переменной, которая нигде в области видимости не объявлена (неявной инициализацией с присвоением значения, явным образом с использованием ключевого слова “Перем”, или передана в качестве параметра)
- Написание на клиенте серверного кода. Например, обращение к менеджеру справочников “Справочники”, и т.п. Клиентская часть приложения “не видит ” серверные объекты языка
- Также ошибка может появиться, если ранее код использовался в режиме толстого клиента, но после был запущен в тонком клиенте.
Как исправить?
Внимательно следить за правильностью набранного кода, своевременно объявлять переменные или передавать их в качестве параметров. Писать серверный код только в серверных модулях, а также использовать соответствующие инструкции препроцессора, например “&НаСервере”.
Значение не является значением объектного типа
Ошибка “Значение не является значением объектного типа” может возникнуть при неверном обращении к объекту языка. Объектный тип – это такие объекты языка, которые содержат в себе другие объекты – свойства, реквизиты и т.п. Эти свойства доступны через точку, например “Объект.СвойствоЭтогоОбъекта”
Но если через точку попытаться использовать какое-то значение, которое внутри себя свойств не имеет – например, любое значение примитивного типа – это и приведет к ошибке.
Разберем более сложный пример:
&НаСервере Процедура ЗначениеНеЯвляетсяЗначениемОбъектногоТипаНаСервере(Справочники = Ложь) Сообщить(Справочники.Сотрудники.ПустаяСсылка()); КонецПроцедуры
Ошибка может быть “плавающей”. Если вместо параметра по умолчанию “Справочники = Ложь” будет передан менеджер справочников, то ошибки возникать не будет. А если вызвать процедуру без параметров, то будет использоваться параметр по умолчанию с типом Булево, что и приведет к ошибке.
Чаще всего чтобы исправить ошибку, нужно в отладчике посмотреть, какой тип значения используется. Можно внести изменения в код, чтобы обеспечить корректное поведение (например, в запросе вместо наименования товара выбрать ссылку, и в коде через точку уже обращаться к свойствам ссылки, а не текстового наименования). А можно добавить проверку на нужный тип значения. Т.е. – если значение того типа, который мы ожидаем – выполняем код. Иначе – не выполняем.
Ошибка при вызове метода контекста
В языке 1С у разных объектов (запросов, справочников, табличных документов и др.) есть предопределенные методы, предусмотренные платформой. Обращение к этим методам требует соблюдения порядка и параметров, правильного синтаксиса и соблюдения условий использования. Например, при чтении табличного документа из файла он не должен быть открыт в другой программе, при подключении к http-соединению оно должно быть доступно, и т.п.
Если эти условия не соблюдать, платформа в зависимости от версии может выдавать сообщения вида “Ошибка при вызове метода контекста”, и далее будут следовать более подробные сведения об ошибке – стек вызовов, приведших к ошибке, номер строки и позиции в строке, где произошла ошибка.
Чаще всего ошибка при вызове метода контекста встречается в следующих методах:
- Записать
- Прочитать
- Выполнить
- Создать
- ПроверитьВывод
Разберем эту ошибку на примере метода Выполнить объекта Запрос:
Запрос = Новый Запрос("ВЫБРАТЬ ПЕРВЫЕ 1 1 ГДЕ ИСТИНА И"); Запрос.Выполнить();
В тексте запроса допущена ошибка – после первого условия “ГДЕ ИСТИНА” указан оператор И, но после него нет еще одного условия. В результате при попытке выполнения запроса, платформа вернет ошибку.
Для исправления ошибки зачастую достаточно внимательно использовать методы, при необходимости уточнять порядок, количество и тип параметров – это можно сделать в справке или синтакс-помощнике (встать курсором на имя метода в коде, и нажать сочетание клавиш Ctrl+F1). В случае запроса – нужно передавать синтаксически корректный текст запроса; в случае проверки вывода на печать – в системе должен быть установлен принтер; в случае подключения к почте – должны быть корректно указаны логин и пароль, и т.п.
Тип не может быть выбран в запросе в 1С 8.3 (8.2)
С такой ошибкой начинающие разработчики (да и не только начинающие 😉 ) сталкиваются чаще всего, при чтении запросом данных из таблиц значений, либо из регистров сведений. Все дело в том, что запросы поддерживают далеко не все типы значений. Так, например, нельзя запросом выбрать тип Картинка, ХранилищеЗначений, Шрифт, и многие другие типы, которые не относятся к примитивным или ссылочным типам значений.
Так, если ресурс регистра сведений имеет тип ХранилищеЗначений, выбрать его запросом будет нельзя. Также, если в таблицу значений поместить значения не подходящих типов, а после передать эту таблицу в качестве параметра-источника данных, выполнение запроса также приведет к ошибке “Тип не может быть выбран в запросе”.
Еще одна ситуация, когда запрос будет выдавать ошибку – если таблица значений, которая передается в качестве параметра, имеет не типизированные колонки.
Неверно:
//ТЗОшибочныйТип.Колонки.Добавить("Контрагент");
Верно:
//ТЗОшибочныйТип.Колонки.Добавить("Контрагент", Новый ОписаниеТипов("СправочникСсылка.Контрагенты"));
Для исправления ошибки нужно правильным образом инициализировать колонки таблицы значений, а также не обращаться в запросе к полям, типы которых запросами не поддерживаются.
Использование в 1С модальных окон в данном режиме запрещено
Платформа будет выдавать такое сообщение, если в коде используются методы, приводящие к открытию модальных окон. Модальные окна – это окна, которые при открытии блокируют весь остальной интерфейс. В 1С есть несколько модальных методов – например – “Вопрос”, “ОткрытьЗначение”, “Предупреждение”. Кроме того, в коде может использоваться модальный синтаксис открытия форм: “ОткрытьМодально()”
Если в свойствах конфигурации выбран режим использования модальности “Не использовать”, то выполнение модальных методов будет приводить к этой ошибке “Использование в 1С модальных окон в данном режиме запрещено”.
Для устранения ошибки можно пойти несколькими путями. Как водится, один – быстрый, другой – правильный 🙂
Быстрый способ – переключить режим использования модальности в положение “Использовать”.
Более правильный способ – использовать в коде немодальные вызовы методов. Например, у метода “Вопрос” есть немодальный аналог – “ПоказатьВопрос”, у метода “Предупреждение” – “ПоказатьПредупреждение”, и т.п. Чаще всего об этих методах дополнительно указано в синтакс-помощнике и справке.
Кроме того, в последних версиях платформы появились асинхронные методы – “ВопросАсинх”, “ПредупреждениеАсинх” и др. Появление этих методов позволяет писать более простой и понятный асинхронный код, и направлено в первую очередь, на более полноценную поддержку браузерами и работу в веб-клиенте.
1С 8.3 и 8.2: Запись с такими ключевыми полями существует!
Данная ошибка появляется при некорректной записи в регистр сведений. Чаще всего с этой ошибкой сталкиваются начинающие разработчики, не до конца понимающие механизмы работы с ключевыми полями (измерениями).
Суть ошибки следующая – регистр сведений позволяет записать запись (строку таблицы) с уникальным набором ключевых полей – а для периодических регистров также и поля Период. Если следующая запись полностью повторяет значение ключевых полей, но осуществляется методом Записать с параметром Замещать = Истина, то запись в таблице регистра просто заменится на идентичную.
Однако если поместить две абсолютно одинаковые записи в набор записей, и попытаться его записать – платформа выдаст ошибку. Еще один распространенный случай, когда 1С сообщает “Запись с такими ключевыми полями существует” – это запись в периодический регистр сведений с периодичностью от “День” и выше, подчиненный регистратору.
В типовых конфигурациях часто эту ошибку можно воспроизвести, если в пользовательском режиме создать два документа “Установка цен номенклатуры” с одной и той же номенклатурой и за один и тот же день. Попытка провести второй документ приведет к ошибке.
В случае, когда ошибка возникает не в результате действий пользователя, а при выполнении кода, чтобы устранить ее, чаще всего необходимо проанализировать алгоритм записи в регистр. Если запись осуществляется одним набором данных, его предварительно нужно свернуть до уникальных записей. Например, выгрузить в таблицу значений, свернуть, и загрузить в набор записей.
Поле объекта недоступно для записи в 1С
Чаще всего начинающие программисты 1С сталкиваются с этой ошибкой в двух ситуациях.
Первый случай – это попытка редактирования системных полей, недоступных для записи. Например, в модуле формы сама форма будет содержаться в объекте ЭтаФорма. И попытка присвоить этому реквизиту любое значение приведет к ошибке “Поле объекта недоступно для записи”.
Второй случай – и с ним новички как раз допускают больше всего ошибок – это попытка редактирования полей ссылки, а не самого объекта. Чаще всего код выглядит примерно так:
Элемент = Справочники.Сотрудники.НайтиПоКоду("12345"); Элемент.Наименование = "Новое наименование";
Исполнение данного кода приведет к ошибке, т.к. поля ссылки доступны только для чтения, а метод НайтиПоКоду вернет именно ссылку. Чтобы можно было внести изменения, следует из ссылки получить сам объект – используя соответствующий метод ПолучитьОбъект().
Для исправления ошибки зачастую достаточно получить объект из ссылки. В случае же попытки редактирования свойств, доступных только на чтение самый правильный подход – анализировать имеющуюся документацию по этим свойствам, и не пытаться присваивать им значения, если платформа этого не предусматривает.
Ссылка на обработку
По ссылке вы можете скачать внешнюю обработку, в которой воспроизводится большая часть ошибок, описанных в статье. Для воспроизведения части ошибок нужно будет убрать комментарии в коде.
Заключение
Как видите, зачастую ошибки тривиальны, и достаточно просто исправляются. Общие рекомендации – внимательно читать документацию и справку, корректно использовать методы, активно пользоваться отладчиком. Если вы новичок, и хотите освоить программирование в 1С с нуля – могу предложить приобрести мой базовый курс для начинающих. Более подробная информация – по ссылке.
Ольга Александровна Блохина
Эксперт по предмету «1С:Бухгалтерия»
Задать вопрос автору статьи
Модули в 1С
Как и любая программа, программа 1С состоит из модулей, частей. Существует несколько видов модулей:
- общие модули (проведение, отчеты, процедуры общего назначения и т.д.);
- модуль объекта (валюты);
- модуль формы (форма: списка, элемента, подбора и выбора);
- модуль приложения.
Программные модули состоят из разделов:
- объявления переменных;
- процедур и функций;
- основной программы.
Определение 1
Контекст в 1С заключается в окружении модуля и его разделов, т.е. это конкретные переменные, свойства, объекты, метод и события которые могут быть доступны в каждой конкретной точке.
Виды контекста:
- Глобальный контекст указывает открытые для вызова функции;
- Локальный контекст (более низкий уровень) становится доступен в каждой модульной части.
Получай знания в онлайн-школе
Подберем репетитора, поможем понять сложные учебные предметы
Выбрать программу
Существуют правила для доступа процедур, переменных, и функций в модулях:
- В общем модуле не будут доступны для экспорта переменные, процедуры и функции модульных приложений;
- В модульных приложениях существует доступ для экспорта процедур и функций общих модулей;
- В общих модульных частях открыт доступ к экспорту процедур и функций прочих общих модулей;
- Для модульных прикладных объектов и для модульных форм являются доступными переменные, функции и процедуры модулей приложений для экспорта и общих модулей.
Замечание 1
Если какой-либо из форм присвоен основной реквизит, то в настройках этой формы будут содержаться свойство и метод, которые отвечают этому основному реквизиту.
Ошибка модуля
В программе 1С ошибка модуля называется «Ошибка при вызове метода контекста». Такое сообщение об ошибке программа 1С дополняет пояснениями, которые описывают обстоятельства, вызвавшие сбой. Такие объяснения программа выдает только во второй и третий версиях программы. Данное пояснение находится в скобках после сообщения об ошибке, что существенно сокращает время, потраченное на ее исправление.
«Ошибка модуля в 1С: причины и способы исправления» 👇
Самые распространенные пояснения:
- записать;
- создать;
- подключиться;
- connect;
- проверить вывод;
- previewFile1C;
- прочитать;
- выполнить;
- выполнить пакет;
- прочитать изменения.
Данная ошибка может возникнуть по причинам:
- нарушена логическая и физическая целостность информационной базы;
- ошибки при обращении с программой;
- разработчиком ошибочно был введен код;
- внезапное закрытие программы.
Вы можете провести анализ ошибки:
- Сравнить версии программы и конфигурации (может быть повреждена платформа).
- Прочитать весь текст сообщения, т.к. в конце его содержатся рекомендации к её устранению.
- Проанализировать давность ее появления и обстоятельства её появления.
- Проверьте, появлялась ли ранее данная ошибка, т.к. невоспроизводимые ранее не встречавшиеся ошибки, чаще всего не исправляются.
- Если появившаяся ошибка появляется при пользовании программой под другим пользователем, то эту ошибку можно устранить путем очистки кэша, настройки прав, очистки пользовательских настроек.
Способы устранения ошибки
Замечание 2
Перед началом работы с базой обязательно сделайте архивную копию!
Данная ошибка в 99% случаях легко решается. Для этого вам достаточно проанализировать проблему и вызвать справку. Так же вы можете забить конкретную ошибку с пояснением в поиск и найти решение проблемы.
Перед использованием любого метода вы можете получить подсказку о том, как его использовать. Для этого выберете требуемую функцию и нажмите на клавиши на клавиатуре «Ctrl + F1». Программа откроет подсказку по необходимому методу. В конце работы проверьте параметры, которые передаются в функцию, и правильность её использования.
Замечание 3
В качестве профилактики следите за актуальностью релиза конфигурации.
Находи статьи и создавай свой список литературы по ГОСТу
Поиск по теме
Ошибка при вызове метода контекста (Выполнить)
Автор Марат, 17 ноя 2016, 11:24
0 Пользователей и 1 гость просматривают эту тему.
{ОбщийМодуль.ОбщегоНазначения.Модуль(7289)}: Ошибка при вызове метода контекста (Выполнить)
по причине:
{(13, 6)}: Поле не найдено «Док.НомерГТД»
Док.<<?>>НомерГТД КАК НомерГТД,
текст запроса, а ваще то он вам и говорит, что ему не нравится…
Получил помощь — скажи СПАСИБО.
Разобрался сам — расскажи другим.
Получил помощь — скажи СПАСИБО.
Разобрался сам — расскажи другим.
Цитата: Марат от 17 ноя 2016, 14:02
а точнее
В коде общего модуля «ОбщегоНазначения», скорее всего в запросе идущем до строки 7289.
А если серьезно. Вы не назвали конфигурацию, вы не сказали в результате чего возникает ошибка.
Вы не не предоставили НИ-КА-КОЙ информации, чтобы хоть как то можно было вам помочь.
Соответственно и получаете вы общие размытые ответы.
Сейчас ваш вопрос звучит примерно так: «У меня машина не едет, вроде как чего то не хватает. Чего именно?»
при добавлении склада в тч в документ авансовый отчет 1с бух 8,2 при проведении документа вылазиет ощибка которую я указал в теме
Добавлено: 17 ноя 2016, 15:27
Запрос = Новый Запрос;
Запрос.Текст = «
|ВЫБРАТЬ
| Док.НомерСтроки » + ТекстЗапроса + «
|
|ИЗ
| Документ.» + ДокументОбъект.Метаданные().Имя + «.»+ СокрЛП(ИмяТабличнойЧасти) + » КАК Док
|
|ГДЕ
| Док.Ссылка = &ДокументСсылка
|
|УПОРЯДОЧИТЬ ПО
| НомерСтроки»;
// Установим параметры запроса.
Запрос.УстановитьПараметр(«ДокументСсылка» , ДокументОбъект.Ссылка);
Возврат Запрос.Выполнить()
Получил помощь — скажи СПАСИБО.
Разобрался сам — расскажи другим.
Доброго дня.
Ситуация такая: есть несколько торговых точек, неделю назад на одной из них 1С перестала запускаться, и починить было некому.
В данный момент ее починили, она запускается, продавец авторизуется, выбирает свое рабочее место и пытается пробивать товар по ШК. В некоторых случаях получаем ошибку в этот момент:
Цитировать{ОбщийМодуль.СкладыСервер.Модуль(2270)}: Ошибка при вызове метода контекста (Выполнить) Результат = Запрос.Выполнить(); по причине: Ошибка выполнения запроса по причине: У пользователя недостаточно прав на исполнение операции над базой данных.
Повторюсь: не на любой товар, только на некоторые. Само собой, пока система не сломалась неделю назад, такого не было.
Я в 1С совсем не профи и даже не опытный пользователь. Я несчастный сисадмин, которого заставляют это починить. Куда мне смотреть? Что мне искать? Подскажите, пожалуйста.
Версия «Предприятие 8.3 УТ 11».
Vito
29.07.22 — 10:20
Сделал такую интеграцию:
1. на http-сервис приходит GET-запрос с id-документа на сайте
2. http-сервис запускает функцию в общем модуле и передает в нее id-документа
3. функция проверяет нет ли такого документа в 1С (запрос к БД) и если нет создает новый документ.
Проблема:
При отправке запроса с id-документа из домашней сети сервера все работает как часы. Причем аутентификация не требуется: просто строка в браузере.
При отправке из любой внешней сети, например, с postman запрос проходит через http-сервис запускает функцию в общем модуле, но при попытке выполнить первый запрос в коде к БД выдает ошибку: «Ошибка при вызове метода контекста (Выполнить)». При этом в запросе происходит авторизация под пользователем у которого есть админские права + еще некоторые.
В чем может быть проблема? У меня ощущение, что это что-то связанное с правами.
Мультук
1 — 29.07.22 — 10:24
(0)
Что показывает отладчик ?
Vito
2 — 29.07.22 — 10:33
(1) он у меня из hhtp-сервиса не запускается…. открывал тему, но ничего не помогло…
Волшебник
3 — 29.07.22 — 10:35
Посмотри журнал регистрации, там полный текст ошибки
Галахад
4 — 29.07.22 — 10:39
Логику в привилегированный модуль.
Мультук
5 — 29.07.22 — 10:45
(0)
А покажи ка, плиз, текст функции.
У тебя сервис. И похоже ни логов, ни обработок ошибок…
Vito
6 — 29.07.22 — 10:47
(3) Смотрел, ничего там нет
(5) Код несколько сот строк. Проблtма в общем стала ясна. Дал все возможные права пользователю и все сработало! Теперь бы понять какие из прав действительно нужны?
(4) Попробую
Мультук
7 — 29.07.22 — 10:54
(6)
>>> Смотрел, ничего там нет
>>> У тебя сервис. И похоже ни логов, ни обработок ошибок…
После того, как всё работает, но через какое-то время ВДРУГ ломается в продакшене, обычно начинают прикручивать и логи и нормальные сообщения об ошибках.
P.S.
Нельзя впихнуть невпихуемое (c) DED
Vito
8 — 29.07.22 — 11:01
(4) — у меня расширение: привилегированный нельзя сделать — галка неактивна
(7) «После того, как всё работает, но через какое-то время ВДРУГ ломается в продакшене, обычно начинают прикручивать и логи и нормальные сообщения об ошибках.» — знаю. Но я только учусь, с 1С 1,5 месяца. Пока не разобрался как в моем случае делать логирование и обработки ошибок, но планирую это сделать позже в любом случае.
Как думаете, как понять какие все-таки права нужно выдать пользователю, чтобы не было избыточных прав?
arsik
9 — 29.07.22 — 11:09
(6) Добавь в запросах «РАЗРЕШЕННЫЕ». И сразу увидишь откуда ноги растут.
Мультук
10 — 29.07.22 — 11:14
(8)
1) Я бы не стал учиться сразу с расширений. В 1С и без них полно всякого непонятного для неофита (нюансы, ага)
2) Я бы не стал учиться, не имея доступа к отладчику. Сделал бы копию базы, скопировал бы сервис в конфигурацию и там проводил бесчеловечные эксперименты
3) Если учишься (это учебная база) — дай полные права пользователю и не мучайся. Напиши бумажку со словами «НЕЛЬЗЯ давать полные права!», приклей на монитор
И пообещай себе «потом сделать правильно».
Слона нужно кушать по частям
Vito
11 — 29.07.22 — 12:04
(9) — Спасибо попробую
(10) — Пока у меня тестовая база, в прод переведу через пару недель, сроки поджимают. Права, видимо, придется постепенно методом научного тыка чистить.
Возникла также очередная проблема с postmana все проходит, а вот с моего сайта — нет, причем получаю ошибку 500. Хотя http-сервис работает и без вызова функции в общем модуле возвращает 200. Т.е. какая то ошибка в логическом модуле, нужно ее как-то посмотреть, но вот как не соображу.
Vito
12 — 29.07.22 — 22:08
Все получилось:
1. Заработала отладка, теперь точно знаю что она запускается в расширении от http запроса. Но вот пока не пойму как точно, методом слепомноготыка.
2. Когда отладчик заработал сразу увидел, что с сайта приходит в кодировке windows-1251, перекодировал и все ОК.
Волшебник
13 — 29.07.22 — 22:09
(12) Молодец!
1
2
Показывать по
10
20
40
сообщений
Новая тема
Ответить
Zebraaa
Дата регистрации: 16.03.2012
Сообщений: 23
Платформа 1с 8.2.15.310, релиз 1.0.12.2 При открытии стандартного отчета Карточка субконто выдается сообщение: Ошибка при вызове метода контекста (Найти поле). Если доступные поля. Найти поле(Отборы.Элементы [Я]_ Левое значение).=Неопределенно Тогда по причине Несоответствии типов (параметр номер 1) <br>Причем такая ошибка выходит только у одного пользователя, у других все нормально открывается.
Sh_S
Дата регистрации: 02.03.2007
Сообщений: 7730
где-то стоит отбор со сравнением с пустым значением, зайдите в настройку и посмотрите
Zebraaa
Дата регистрации: 16.03.2012
Сообщений: 23
А можно ,пожалуиста, по подробнее!
Sh_S
Дата регистрации: 02.03.2007
Сообщений: 7730
мне кажется теперь, что я не права. Под рукой бухгалтерии нет, но в УПП и ЗУПе если поставить отбор по пустому значению выходит просто шапка отчета. Но все-таки посмотрите внимательно на отборы в настройках.
Zebraaa
Дата регистрации: 16.03.2012
Сообщений: 23
Как я посмотрю, если я даже открыть отчет не могу.Выбираю Карточку субконто и сразу сообщение выдается, выше написанное.
Денис (САМАРА)
Дата регистрации: 09.04.2008
Сообщений: 8351
Платформу обновить до последней. Выполнить тестирование и исправление со всеми флагами.
Zebraaa
Дата регистрации: 16.03.2012
Сообщений: 23
Спасибо конечно! Но я думаю тестирование и исправление тут не причем, так как остальные пользователи в эту базу могут зайти, только один пользователь не может.Платформа вроде бы тоже относительно новая.
Денис (САМАРА)
Дата регистрации: 09.04.2008
Сообщений: 8351
У этого пользователя сохранились настройки отчета в старом формате. Теперь нужно либо как-то очистить эти настройки либо переконвертировать имеющиеся. У других пользователей нет этих старых настроек, вот они и не нарываются на ошибку. Попробуйте почистить кэш на компьютере пользователя.
Zebraaa
Дата регистрации: 16.03.2012
Сообщений: 23
Кстати, самое интересное, что сохраненных настроек по этому пользователю нет, а по другим есть.
Денис (САМАРА)
Дата регистрации: 09.04.2008
Сообщений: 8351
Имеются ввиду «Сохраненные варианты отчета».
Волшебник
21.04.22 — 11:37
Прямо сейчас наблюдаются проблемы с доступом к сайту 1С и её сервисам (проверка контрагентов, обновления)
PLUT
1 — 21.04.22 — 11:40
Irbis
2 — 21.04.22 — 11:40
Было оповещение о Ддосе в сторону 1С
Garykom
3 — 21.04.22 — 11:42
ФСС тоже проблемы
ptiz
4 — 21.04.22 — 11:49
«DDos’серы решили бороться со сдачей отчётности, но не определились с какой именно. Поэтому под прицелом различные сайты и сервисы РАР, и ФСС, и 1С, и Росстата. Ну и за компанию сайты КриптоПро и Инфотекса»
https://t.me/ofd24/3434
Smit1C
5 — 21.04.22 — 11:53
Веб-сайт login.1c.ru использует механизм HSTS. Открыть сайт в настоящее время нельзя. Сбой мог быть вызван сетевой ошибкой или действиями злоумышленников. Скорее всего, сайт заработает через некоторое время.
Bigbro
6 — 21.04.22 — 11:56
мне касперский пишет что используется самоподписанный сертификат идите лесом..
может яндекс браузером теперь только ходить надо.
PR
7 — 21.04.22 — 12:02
(5) Через ie заходит
1Сергей
8 — 21.04.22 — 12:13
(7) + Запустить Ишака под админом, заходит
DEVIce
9 — 21.04.22 — 12:20
(6) Яндекс.Браузер пишет ровно то же самое.
RomanYS
10 — 21.04.22 — 12:20
Через яндекс на мобильном зашел. На страницу релиза пускает, скачать всё равно не дает
yzimin
11 — 21.04.22 — 12:29
(7) всё равно не даёт скачать обновление
Anchorite
12 — 21.04.22 — 12:30
(5) > Сбой мог быть вызван сетевой ошибкой или _действиями_ _злоумышленников_
Не иначе Бухсофт постарался.
Доминошник
13 — 21.04.22 — 12:40
(5) Это «защитник от DDOS-атак» подставляет свой сертификат
asady
14 — 21.04.22 — 13:15
(0) ну дык вчера сап уходил — они там подрасслабились — видимо слишком хорошо отпраздновали событие.
mishaPH
Модератор
15 — 21.04.22 — 13:21
ддосят их.
Адинэснег
16 — 21.04.22 — 13:38
о да, и заполнялка по ИНН пишет 410
Amra
17 — 21.04.22 — 13:46
(14) А потом стали пароли менять….))
rozer76
18 — 21.04.22 — 13:57
(16) как интересно совпало что 1с отменила позавчера старый формат, пришлось срочно впиливать в старенький 1С Документооборот с БИП 2.1 код из БИП 2.2.3.19
Хорошо что их сервис ссылочку шлет в ответ а не только 410ую ошибку
https://portal.1c.ru/download/public/instruction/OLD_Data_1C-Contragent.pdf
RomanYS
19 — 21.04.22 — 13:59
(10) скачал на мобильном через ЯБ
PLUT
20 — 21.04.22 — 14:06
продолжаем наблюдение:
зашел на всем известный сайт, т.е. логин работает, перешел в чисто конкретный релиз новый
но при попытке скачивания —
«Ошибка на нашем сервере
Данный сервис временно недоступен. Мы делаем все возможное, чтобы исправить эту проблему. Попробуйте повторить действие позже.»
Адинэснег
21 — 21.04.22 — 14:24
(18) тьху на них
платим 80к за продление поддержки УПП параллельно ЕРП, а они нам фигвамы рисуют…. 177 релиз
zxc
22 — 21.04.22 — 14:40
Зашел. Все работает.
zxc
23 — 21.04.22 — 14:55
Скачать пока беда(
Деспот_1С
24 — 21.04.22 — 15:10
(0) 1С — фигня, главное чтобы Мисту не завалили!
kovalev_oleg
25 — 21.04.22 — 15:31
(0) Да отчетный период, новые ФСБУ, все качают обновления ,читают инструкции, бывает. Работает с перебоями.
Azverin
26 — 21.04.22 — 15:34
(18) много там пилить или замена ссылки поможет?
Fragster
27 — 21.04.22 — 15:53
(23) ну так значит не все работает
NorthWind
28 — 21.04.22 — 16:06
1C отчетность тоже не работает, как я понимаю?
Garykom
29 — 21.04.22 — 16:21
(28) да не работала
сейчас возможно уже починили
PuhUfa
30 — 21.04.22 — 19:36
ЭДО лежит?
Пишет «Неизвестная ошибка сервиса. Попробуйте позже или обратитесь в службу поддержки.»
Russiagreat
31 — 21.04.22 — 19:41
зашел, все работает. но впервые увидел заставку — защита от DDOS атак. потом переход
lenkavovka
32 — 21.04.22 — 20:37
(30) ЭДО весь день не видим. Формально влетаем по срокам оборота маркируемых товаров, ибо должны сегодня выкупить у поставщика то, что уже продали дальше в розницу.
mishaPH
Модератор
33 — 21.04.22 — 22:26
(30) я с утра не мог на запрос налоговой нажать кнопу уведомлен. Отправка завешивала буз облачный напроч
Klesk
34 — 21.04.22 — 22:45
официально 1с пишут где то об этом?
shestakova
35 — 22.04.22 — 06:19
Всем добра!
1С-Отчетность так и не работает? Или есть вариант обхода?
При отправке реестра в ФСС:
«Не удалось получить файл описания web-сервиса https://login.1c.ru/api/public/ticket?wsdl по причине:
Не удалось получить файл https://login.1c.ru/api/public/ticket?wsdl с сервера login.1c.ru:443
по причине:
Ошибка при выполнении запроса:
[403] К запрашиваемому ресурсу нет доступа.
Сообщение, полученное от сервера:
ddos_3 (…)»
Bigbro
36 — 22.04.22 — 07:27
врода заработала авторизация норм все
lenkavovka
37 — 22.04.22 — 07:39
(36) «норм» совсем не всё. 1С-ЭДО по прежнему в отключке, по крайней мере попытки обмена с оператором заканчиваются ошибкой интернет-соединения.
shestakova
38 — 22.04.22 — 07:40
у меня на сервере зависает «Проверка браузера перед переходом на сайт login.1c.ru»..
Flempy
39 — 22.04.22 — 08:12
При попытке получить данные о больничном с ФСС возникает следующая ошибка
При обращении по URL: https://eln.fss.ru/ws-insurer-crypto-v20/FileOperationsLnService?wsdl
Подключение проводится на сервере 1С:Предприятие <server-1C>.
Отсутствует доступ в сеть интернет по причине:
— компьютер не подключен к интернету;
— неполадки у интернет-провайдера;
— подключение к интернету блокирует межсетевой экран,
антивирусная программа или другое программное обеспечение.
Это связанные проблемы?
NorthWind
40 — 22.04.22 — 08:48
интересно, что будет дальше… в понедельник 25 число и сроки сдачи отчетности. 1С отчетность становится несколько срочно нужна.
vdeemer
41 — 22.04.22 — 11:29
Нет новых данных на ЭДО-фронте?
Получение файла из интернета
Не удалось получить файл https://downloads.v8.1c.ru/content/LED/settings/format_conversion_rules/supported_formats_v20.xml с сервера downloads.v8.1c.ru:443
по причине:
Ошибка при выполнении запроса:
[403] К запрашиваемому ресурсу нет доступа.Сообщение, полученное от сервера:
ddos_3
Deal with it
42 — 22.04.22 — 11:34
Скачать обновление получилось, без каких либо ошибок.
neomarat
43 — 22.04.22 — 11:48
Автоматическое обновление не работает из программ
Garykom
44 — 22.04.22 — 12:49
https://habr.com/ru/news/t/662385/
21 апреля пользователи Сети начали сообщать о проблемах с работой всех сервисов 1С. Недоступны обновления, невозможно зайти в личный кабинет и на сервис ИТС, не работает ЭДО и 1С:отчётность. 25 числа необходимо подавать отчёт в налоговую, но его невозможно подготовить из-за сбоя.
Anchorite
45 — 22.04.22 — 13:02
(42) > Скачать обновление получилось, без каких либо ошибок.
Лишь бы файлы не оказались битые, а то вот смеху-то будет, если кто про запас скачал, чтобы на выходных обновиться.
Deal with it
46 — 22.04.22 — 13:15
(45) распаковал, установил, вроде норм все)
Garykom
47 — 22.04.22 — 13:17
(46) скажи как патчи-расширения к БП3 скачать
Anchorite
48 — 22.04.22 — 13:20
(46) А можыт и не норм, там же zip и crc32, чиста тиваритически ошибки целостности вполне возможны, 1С же не снисходит до того, чтобы контрольные суммы MD5 публиковать.
vdeemer
49 — 22.04.22 — 14:25
Garykom
50 — 22.04.22 — 14:47
Garykom
51 — 22.04.22 — 14:48
(50)+ который «размер 0, сжатый 2» понятно дело битый
Anchorite
52 — 22.04.22 — 16:06
(50) (51) Перекачайте, так теперь часто бывает в нынешнее неспокойное время. Иной раз только с пятой попытки скачивается нормально.
vdeemer
53 — 22.04.22 — 21:25
Камрады, 1С:ЭДО по-прежнему недоступен?
дущ1
54 — 22.04.22 — 21:31
В 1С:Линк тоже не могу туннель зарегистрировать. Самое главное от 1С — молчок. Ни новости на сайте, ни инфописьма: «Улыбаемся и машем»
vdeemer
55 — 22.04.22 — 21:54
Я им письмо рисовал со всеми картинками, ошибками, ЖР… Цитата:
Здравствуйте! 21.04 на сайты 1С, 1С-Отчетности, ФСС и ПФР шла массовая DDOS-атака. Специалисты решали эту проблему. Попробуйте еще раз сегодня. С уважением, отдел тех. поддержки фирмы "1С" Тел. (495) 956-11-81 (линия ИТС) (495) 688-10-01 (базовые версии)
Amra
56 — 22.04.22 — 22:02
(55) Раз 100…
PuhUfa
57 — 23.04.22 — 06:59
(53) У меня, в БП, со вчерашнего вечера работает.
Garykom
58 — 24.04.22 — 13:24
Garykom
59 — 24.04.22 — 13:24
(58)+ DDoS атаки по России. Расследование атаки на наш проект
Привет!
Решил рассказать как мы расследовали DDoS атаку на свой проект. Это не реклама моего проекта, просто хочу поделиться тем, как это работает. Так что упоминать что за проект не буду. Возможно, механика этой атаки поможет кому-то справиться с атакой на его проект.
Волшебник
Модератор
60 — 24.04.22 — 13:41
(58)
Список атакуемых сайтов из статьи:
https://pastebin.com/7zs8T4cA
В списке «Мин.обороны РФ» и «Денис Пушилин», «Новости Саратова», «Волгоград»
Krendel
61 — 24.04.22 — 13:42
(60) А где миста?
Волшебник
Модератор
62 — 24.04.22 — 13:43
(61) В каком-то другом списке
Krendel
63 — 24.04.22 — 13:44
(62) Я думал, нас уже ломанули в глушняк
Krendel
64 — 24.04.22 — 13:44
сутки не было доступа до мисты
Волшебник
Модератор
65 — 24.04.22 — 13:47
(64) Это всё они, враги нашей Родины. Мы тоже на войне.
Krendel
66 — 24.04.22 — 14:00
Ждем видимо, когда уже надоест и вся страна как китай будет сидеть на 10мбитахьс внешним миром
NorthWind
67 — 24.04.22 — 14:32
(66) так атакуют необязательно из-за рубежа. В России и своих зараженных машин достаточно, и даже серверов.
Garykom
68 — 24.04.22 — 17:12
(67) В данном случае ломают сайты на WordPress
Или что вероятней не ломают а бэкдоры в плагинах 404 и прочего происхождения
Garykom
69 — 24.04.22 — 17:13
(68)+ В результате все посетители подобных ломаных сайтов принимают участие в ddos атаках
Arh01
70 — 24.04.22 — 18:24
(53) У меня 1С-ЭДО до сих пор не не работает. На разных учетках, в разных организациях проверяю.
ДедМорроз
71 — 24.04.22 — 19:05
(69) это называется BotNet.
И,самое печальное,что их запросы отличить от других запросов не всегда просто.
Мигрень
72 — 24.04.22 — 19:33
у меня Миста не открывается вообще третий день
Волшебник
Модератор
73 — 24.04.22 — 20:12
(72) Сейчас всё нормально?
MWWRuza
74 — 24.04.22 — 20:44
(73) Со вчерашнего дня, очень плохо работало, по нескольку раз страницы не открывались… Потом, все-таки после долгих мучений открывались.
А сегодня, где-то с половены дня, «как выключателем щелкнули», стало работать отлично, все проблемы ушли.
Волшебник
Модератор
75 — 24.04.22 — 20:50
(74) Ну ОК. Если что, пишите в личку
Мигрень
76 — 24.04.22 — 21:10
(73) два дня чесал репу, на третий день путем сильного перенапряжения умственных способностей решил добавить к названию сайта буквы «/index.php», после этого стало открываться
Asmody
77 — 25.04.22 — 07:21
(74) просто мне в субботу было не до мисты. А вчера Волшебник практически вытащил меня из постели с куском кулича в зубах, и отправил на передовую. Прям в таком виде. Пришлось отбиваться от всех и сразу.
Asmody
78 — 25.04.22 — 07:32
(71) если интересно, я потом напишу какие сейчас атаки и как мы отбиваемся
Winnie Buh
79 — 25.04.22 — 07:57
до инфостарта похоже добрались
SleepyHead
80 — 25.04.22 — 08:02
(78) Интересно
На компе открывается. На смартфоне почему-то. Странно.
MWWRuza
81 — 25.04.22 — 09:40
Сейчас опять началось… Через раз, на компе. Как было два предыдущих дня, один в один.
Asmody
82 — 25.04.22 — 10:42
я наблюдаю атаки двух видов:
1) обычный ботнет. может быть несколько. атакует кучей запросов с большой частотой с разных ip.
2) «облачный кубернетис». отличается тем, что залпом отправляет запросы сразу с кучи ip из одной подсети. при этом, с каждого адреса может быть немного запросов.
Первый случай успешно ловится связкой ngx_http_limit_req_module + fail2ban. Первый отслеживает частоту и количество запросов с одного ip, второй — по логам первого отправляет адреса в блок на фаерволе.
Со вторым случаем эта связка менее эффективна, поскольку поведение каждого адреса не сильно отличается от обычного пользователя. При этом, блокировка атакующих адресов по одному не сильно спасает. Видимо, атакующая прога написана таким образом, что при блокировке ip нода гасится и поднимается уже на другом адресе. Как та самая гидра — отрубаешь одну голову, на её месте вырастает две.
Пока приходится в полуручном режиме по логам выявлять подсети и руками заносить их в блок.
Mraque
83 — 25.04.22 — 10:50
1С: Отчетность по прежнему лежит?
У нас в УПП ошибка при начале обмена:
При вызове веб-сервиса произошла ошибка. Ошибка вызова операции сервиса: {http://regservice.keydisk.ru/}:RegService:ReceiveUpdatedPacket()
по причине:
При вызове веб-сервиса произошла ошибка. Неизвестная ошибка. Ошибка работы с Интернет: Удаленный узел не прошел проверку
До Калуги-Астрал не дозвониться, не дописаться…
1Сергей
85 — 25.04.22 — 14:03
(41) У нас раздуплилось
olo_lo1
86 — 25.04.22 — 14:13
Вот такая ошибка вылазит ..
При вызове веб-сервиса произошла ошибка. Ошибка HTTP: HTTP Status 410.
.
<soap:Envelope xmlns:soap=»http://schemas.xmlsoap.org/soap/envelope/»>
<soap:Body>
<soap:Fault>
<faultcode>soap:Server</faultcode>
<faultstring><![CDATA[410 — Gone. See details at https://portal.1c.ru/download/public/instruction/OLD_Data_1C-Contragent.pdf ]]></faultstring>
</soap:Fault>
</soap:Body>
</soap:Envelope>
{ОбщийМодуль.ДанныеЕдиныхГосРеестров.Модуль(31)}: Ответ = Прокси.getCorporationRequisitesByINN(ВходныеПараметры);
{Справочник.Контрагенты.Форма.ФормаЭлемента.Форма(1963)}: РеквизитыКонтрагента = ДанныеЕдиныхГосРеестров.РеквизитыЮридическогоЛицаПоИНН(СтрокаИНН);
по причине:
При вызове веб-сервиса произошла ошибка. Ошибка вызова операции сервиса: {http://ws.orgregister.company1c.com/}:RequisitesWebServiceEndpointImpl7Service:getCorporationRequisitesByINN()
по причине:
При вызове веб-сервиса произошла ошибка. Ошибка HTTP: HTTP Status 410.
.
<soap:Envelope xmlns:soap=»http://schemas.xmlsoap.org/soap/envelope/»>
<soap:Body>
<soap:Fault>
<faultcode>soap:Server</faultcode>
<faultstring><![CDATA[410 — Gone. See details at https://portal.1c.ru/download/public/instruction/OLD_Data_1C-Contragent.pdf ]]></faultstring>
</soap:Fault>
</soap:Body>
</soap:Envelope>
Winnie Buh
87 — 25.04.22 — 15:45
(83) В связи с изменением сертификата удостоверяющего центра пользователям версий конфигураций 1С:Бухгалтерия 2.0 КОРП, Зарплата и кадры КОРП 2.5, Управление производственным предприятием 1.3 и всех конфигураций, работающих на платформе 1С:Предприятие 8.2 или на платформе 8.3 в режиме совместимости с со старыми версиями платформы необходимо обновить сертификат.
Для обновления сертификата необходимо выполнить следующие действия:
— закрыть все работающие сеансы 1С:Предприятие
— сделать копию старого сертификата
— заменить файл со старым сертификатом в каталоге, в котором установлена платформа, например C:Program Files (x86)1cv88.3.20.1769bincacert.pem
Замена возможна тремя способами:
— Заменить файл cacert.pem на другой, уже содержащий новый сертификат ISRG Root X1. Если вы ранее не редактировали cacert.pem, то этот вариант предпочтителен. Архив файла cacert.pem для замены доступен по ссылке https://its.1c.ru/db/files/1CITS/EXE/cacert/cacert.zip.
— Добавить текст сертификата ISRG Root X1 при помощи обработки, выполняющей поиск и редактирование файла cacert.pem на компьютере пользователя в автоматическом режиме. Архив обработки доступен по ссылке https://its.1c.ru/db/files/1CITS/EXE/digicert_epf/digicert_epf.zip. Обработка обновляет сертификат только на клиентском компьютере, поэтому такой способ подойдет только для файлового варианта информационной базы.
— Добавить текст сертификата ISRG Root X1 вручную в конец файла cacert.pem в любом текстовом редакторе. Архив с текстом сертификата доступен по ссылке https://its.1c.ru/db/files/1CITS/EXE/digicert/digicert.zip.
Garykom
88 — 25.04.22 — 16:14
(82) >при блокировке ip нода гасится и поднимается уже на другом адресе.
а нельзя ли аналог теневого бана заюзать?
ну чтобы атакующий не понимал что его атаки не работают, отправлять все запросы на другой эмулирующий сервер
Волшебник
Модератор
89 — 25.04.22 — 16:17
(88) Проблема именно в фильтрации полезных и паразитных запросов. Если бы был алгоритм, то мы бы просто сделали DROP для паразитных запросов
Garykom
90 — 25.04.22 — 16:26
(89) Так суть как раз не делать drop чтобы атакующий не менял ip и не приходилось снова искать паразита
Волшебник
Модератор
91 — 25.04.22 — 16:36
(90) Ежедневно у нас бывает 50 тыс IP. Из них 20 тыс паразитных
Garykom
92 — 25.04.22 — 16:40
(91) ML прикрутить не?
Волшебник
Модератор
93 — 25.04.22 — 16:42
(92) Что это?
MaxS
94 — 25.04.22 — 16:43
На Windows 10 закачалось обновление, просит перезагрузить. Стоит ли доверять?
Касперский стоит. Стоит ли на него надеяться, что он деструктивные обновления Windows не пропустит?
Если по теме, то не хотелось бы быть соучастником атак после установки полезных обновлений.
Волшебник
Модератор
95 — 25.04.22 — 16:45
(94) Вы очень наивны, если думаете, что Касперский не пропустит обновление Windows.
Винда главнее
vde69
96 — 25.04.22 — 16:48
я на домашних компах обновления зарубил, включая ИХ IP на роутере
Garykom
97 — 25.04.22 — 17:11
MaxS
98 — 25.04.22 — 17:14
Обновления загружаются вручную. Решил рискнуть. Это вспомогательный виртуальный комп. Сегодня перезагружу.
Проверил свой ip в спам базах. Ничего нет кроме:
Usage classification (only important if you run your own mailserver.)
2 «DUHL» entries [09:53:43 17 Oct 2011 GMT-04].
На рабочем компе ни обновлений, ни интернета нет.
(94) Ну может быть касперский умеет закрывать атаки не только извне, но и блокировать атаки наружу из себя самого.
unitpro67
99 — 25.04.22 — 17:18
Всем привет . Розница 2.3 . Отвалилось ЭДО с ошибкой неверный логинпароль интернет поддержки. Пробую другие логинпароли — ошибка та же . На других ПК с этой же связкой все нормально работает.
Захожу под конфигуратором и пробую обновить конфигурацию онлайн — 1С моментально крашится с этой ошибкой
Ошибка источника потока
по причине:
Ошибка доступа к файлу ‘http://downloads.v8.1c.ru/tmplts/v8cscdsc.lst’
по причине:
Ошибка работы с Интернет: доступ запрещен (403). <!DOCTYPE html><html><head><title>DDOS-GUARD<
unitpro67
100 — 25.04.22 — 17:25
Обновился вручную — результат тот же
Подключился с другого IP — все то же самое
Кэш почистил, тестированиеисправление — все пробовал , нихрена не пойму .
В тексте ошибки вижу ддос гард — понимаю что банят, но как исправить не пойму
Для корректной работы сервиса 1С-Отчетность необходимо проверить следующие настройки:
Примечание. Данные настройки производятся системным администратором (или под его руководством).
1. Антивирусы и межсетевые экраны.
При наличии антивируса и
межсетевого экрана (firewall, брандмауэр) в их настройках не должно быть
ограничений для прямого доступа к необходимым серверам. Если в системе
настроена проверка SSL — её необходимо отключить.
2. Прокси сервер.
Если соединение с интернетом проходит
через прокси-сервер, необходимо разрешить прямой доступ в обход прокси
для используемых серверов, а также настроить авторизацию на прокси-сервере в 1С для передачи отчетности.
3. Порты передачи данных.
Обязательно следует открыть порт 80 HTTP.
Далее, в зависимости от того, обмен с какими контролирующими органами используется:
1). Обмен с ФНС, ПФР, Росстатом
- 465 SMTP и 110 POP3 (резервные 25 SMTP и 995 POP3)
- report.keydisk.ru (31.13.60.76)
2). Обмен с Росалкогольрегулированием
- 443 HTTPS
- service.fsrar.ru (146.120.90.20)
3). Обмен с ФСС
- 80 HTTP, 443 HTTPS
- f4.fss.ru (193.148.44.187) (отправка 4-ФСС)
- docs.fss.ru (193.148.44.187) (реестры больничных листов)
- cabinets.fss.ru (193.148.44.188) ; portal.fss.ru (193.148.44.186) (реестры ЭЛН)
4). Обмен с Росприроднадзором
- 443 HTTPS
- lk.fsrpn.ru (37.16.80.199)
5). Обмен с ФТС
- 80 HTTP
- edata.customs.ru (77.108.76.27)
6). Обновления 1С/модуля документооборота
- 80 HTTP
- downloads.1c.ru (89.111.148.68)
7). Обновления учетной записи
- 80 HTTP
- regservice.keydisk.ru (91.239.5.33)
Доступ к портам можно проверить с помощью командной строки. Для этого перейдите в меню Пуск → Выполнить и впишите cmd. В открывшейся командной строке введите команду telnet, через пробел адрес сервера и через пробел соответствующий ему порт.
Например: telnet report.keydisk.ru 465
Примечание. Клиент telnet может быть отключен в системе. При использовании команды с выключенным клиентом telnet появится сообщение Команда telnet не является внутренней или внешней компонентой. Для включения клиента telnet необходимо перейти в Панель управления → Программы и компоненты → Включение и отключение компонентов Windows и проставить флажки на пунктах клиент telnet и сервер telnet.
Мобильный клиент ведет себя еще более странно и отловить реальную ошибку очень тяжело, особенно когда переделывает чужие формы под мобильный клиент.
Мнение эксперта
1С:Эксперт по технологическим вопросам
Задавайте мне вопросы, и я помогу разобраться!
Причина была в отсутствии атрибута targetNamespace у тега , соответственно 1С не знала, в какой пакет помещать схему, но ошибок не выдавала. 1C Веб Сервис Ошибка При Вызове Метода Контекста Обращайтесь в форму связи
Обмен данными обычно организовывается с помощью выгрузки файла из одной программы и загрузки в другую. Некоторые программисты предоставляют сторонним программам доступ в SQL базу 1С (что вроде как сильно не рекомендуется).
Термин «обмен данными» не всегда подходит к задаче, иногда более корректно сказать – предоставление данных. Например, внешней программе требуется идентифицировать – существует ли такой клиент в 1С и его баланс.
Предоставление доступа к данным 1С – некорректно по причинам безопасности данных. Необходим скорее механизм проверки по имени и паролю с дальнейшим возвратом баланса.
Этот подход называют – сервисным, когда программа предоставляет не данные, а сервис, который позволяет идентифицировать клиента и узнать его баланс.
SOA – «сервис ориентированная архитектура» – означает, что программы для обмена данными друг с другом используют «сервисы».
Веб сервис – это набор функций (процедур), которые могут быть вызваны извне программы и базы данных.
Для того, чтобы другая программа знала, что такой «сервис» есть у этой программы, первая на веб сайте выкладывает сведения о своих сервисах. Формат такого описания – файл WSDL.
Функции извне вызываются (запускаются) запросом по протоколу SOAP.
Для передачи параметров и результатов используется XML. Для работы с веб-сервисами Вы должны иметь базовое понимание про XML и XDTO.
Web сервис 1С это способ, с помощью которого можно разрешить запускать некоторые функции 1С снаружи базы 1С, в том числе из других программ или других баз 1С.
Это лучше, чем предоставление прямого доступа к данным 1С, так как при вызове метода (функции) web сервиса 1С, доступ к данным внешняя программа не имеет. Функция на языке 1С самостоятельно определяет право внешней программы получить конкретную толику данных по переданным параметрам (например, имени и паролю).
Промокоды на Лайм Займ на скидки
Займы для физических лиц под низкий процент
- 💲Сумма: от 2 000 до 70 000 рублей
- 🕑Срок: от 7 до 168 дней
- 👍Первый заём для новых клиентов — 0%, повторный — скидка -10 % по промокоду
Web сервис 1С это объект 1С, который находится в конфигурации, в ветке Общие/Web-сервисы.
Так как функционирует web сервис 1С с помощью XML пространство имен и пакет XDTO. XDTO пакеты 1С мы обсуждали ранее.
Во многих случаях, можно не создавать свой пакет XDTO, а использовать по умолчанию – выбрав из списка пакет www.sample-package.org
После этого нужно добавить список функций (методов веб сервиса 1С) – которые будут предоставляться наружу. Называть их лучше англоязычно. Функция может иметь параметры.
Для каждой добавленной функции веб сервиса 1С, в свойствах нужно создать обработчик, так же, как мы это делали в командах 1С, подписках на событиях 1С и так далее.
Именно эта функция 1С будет выполняться при вызове метода веб сервиса 1С. Не забывайте, что выполняться она будет на сервере 1С. Файловый режим работы 1С с веб-сервисами не рекомендуется.
Функция обычно возвращает какие-либо данные. Обычно указывают тип string и возвращают строку XML.
Строку XML можно сформировать с помощью объектов языка 1С для работы с XML – ДокументDOM и ФабрикаXDTO, а можно просто составить текстовую строку, в которой хранится текст XML.
Ошибка модуля в 1С: причины и способы исправления
- Иметь веб сайт
- В свойствах web сервиса 1С указать имя файла с расширением 1cws, который является ссылкой на WSDL описание
- Выложить этот файл на веб сайт в конфигураторе с помощью пункта меню Администрирование/Публикация на веб-сервере.
Для того, чтобы выполнить публикацию Web -сервисов, следует выполнить команду меню Администрирование Публикация Web-сервисов.
Мнение эксперта
1С:Эксперт по технологическим вопросам
Задавайте мне вопросы, и я помогу разобраться!
Выделить отдельный сертификат ЭЦП, который не подписывает ЭД, для проведения сеансов связи с Такском в клиент-серверном варианте. При создании описания сервиса произошла ошибка: новый wsопределения 1С Обращайтесь в форму связи
1C Веб Сервис Ошибка При Вызове Метода Контекста
Рассмотрим основные ошибки, которые могут возникать при проведении различных документов в программе 1С-Рарус: Ломбард 4.
1. Ошибка при вызове метода контекста (Записать): Запись не верна! Не заполнен счет дебета
Горящие товары с бесплатной доставкой
«AliExpress Россия» работает отдельно от глобального «AliExpress» принадлежащего Alibaba. Он не зависит от мировых банковских систем и не попал под санкционный список со стороны США и Великобритании. Из Китая соответственно тоже можно заказывать ничего не опасаясь.
Данное сообщение может возникать при проведении кассовых документов на закладке «Документы»:
Сообщение возникает в том случае, если в регистре сведений «Счета учета расчетов с контрагентами» не заполнен счет расчетов с покупателем (пункт меню «Справочники – Контрагенты – Счета расчетов с контрагентами»):
Счета учета расчетов можно указать для определенной организации, контрагента или группы контрагентов, для отдельного договора или вида расчетов. Для этого необходимо создать соответствующее число записей в регистре сведений:
Можно разделить счета учета расчетов с контрагентами по типу контрагентов, например, для залогодателей и прочих контрагентов. Для этого необходимо заполнить поле «Контрагент» (при этом можно указать как конкретное юридическое или физическое лицо, так и группу контрагентов):
2. Поле «Счета учета расчетов за хранение»/«Счет учета расчетов за кредит»/«Счет учета расчетов за просрочку» не заполнено
Сообщения могут возникать при проведении документа «Начисление процентов»:
При возникновении подобных сообщений можно указать необходимые счета непосредственно в каждом документе «Начисление процентов» на закладке «Счета учета расчетов».
Для того, чтобы счета учета расчетов за каждый вид процентов заполнялись автоматически, в Учетной политике по Ломбарду (меню «Главное – Настройки по Ломбарду – Учетная политика») на закладке «Регламентированный учет – Счета учета расчетов») необходимо заполнить счета учета расчетов:
Сообщение может возникать при проведении документа «Начисление процентов»:
Данное сообщение говорит о том, что в документе «Начисление процентов» на закладке «Счета учета расчетов» не заполнены значения Счетов доходов от кредита, хранения и просрочки. Их можно заполнить непосредственно при проведении документа.
Для того, чтобы указанные счета заполнялись автоматически, необходимо заполнить соответствующие данные в специальном разделе «Счета расчетов по залоговому билету» (меню «Ломбард – См.также – Счета расчетов по залоговому билету»):
Счета учета доходов при необходимости можно разделить по организациям и контрагентам/группам контрагентов.
Сообщение может возникать при проведении документа «Операция по залогу»:
Данное сообщение возникает тогда, когда в настройках Схемы кредитования выбран вариант момента получения процентов «Взимать сразу», а на закладке «Счета учета» не заполнены данные о счетах учета доходов и расчетов по каждому виду начислений:
Для автоматического заполнения данных счетов необходимо настроить счета учета расчетов в Учетной политике по ломбарду и счета расчетов по залоговому билету, описанные в п. 2 и 3.
Web сервисы 1С
Для того, чтобы выполнить публикацию Web -сервисов, следует выполнить команду меню Администрирование Публикация Web-сервисов.
Мнение эксперта
1С:Эксперт по технологическим вопросам
Задавайте мне вопросы, и я помогу разобраться!
Можно разделить счета учета расчетов с контрагентами по типу контрагентов, например, для залогодателей и прочих контрагентов. 1С ошибка при вызове метода контекста Обращайтесь в форму связи
Пример использования динамической WS-ссылки
// Создать WS-прокси на основании WS-определения
Определение = Новый WSОпределения (“http://www.MyCompany.ru/shipment/ws/Shipment.1cws?wsdl”);
Прокси = Новый WSПрокси ( Определение , “http://www.MyCompany.ru/shipment”, “ДанныеРасходнойНакладной”, “ДанныеРасходнойНакладнойSoap”);
В то время как создание WS-прокси на основе статической ссылки выглядит следующим образом:
На закладке Основные вводится имя, синоним и комментарий объекта.
На закладке Операции создаются подчиненные объекты Операции, которые, в свою очередь, могут иметь подчиненные объекты Параметры, необходимые для работы с объектами данного типа. Описание подчиненных объектов выполняется в палитре свойств.
Помимо общих свойств объектов конфигурации операция Web-сервиса содержит следующие свойства:
1С-Рарус: Ломбард – основные ошибки при проведении документов в программе и как с ними работать
Пример использования динамической WS-ссылки
// Создать WS-прокси на основании WS-определения
Определение = Новый WSОпределения (“http://www.MyCompany.ru/shipment/ws/Shipment.1cws?wsdl”);
Прокси = Новый WSПрокси ( Определение , “http://www.MyCompany.ru/shipment”, “ДанныеРасходнойНакладной”, “ДанныеРасходнойНакладнойSoap”);
В то время как создание WS-прокси на основе статической ссылки выглядит следующим образом:
На закладке Основные вводится имя, синоним и комментарий объекта.
На закладке Операции создаются подчиненные объекты Операции, которые, в свою очередь, могут иметь подчиненные объекты Параметры, необходимые для работы с объектами данного типа. Описание подчиненных объектов выполняется в палитре свойств.
Помимо общих свойств объектов конфигурации операция Web-сервиса содержит следующие свойства: