دریافت داده از طریق اتصال com از 1s. V8: اتصال COM. دریافت و مقایسه شمارش از طریق اتصال COM
سوال: تجزیه سایت با استفاده از COM IE 11
پاسخ:
سوال: اتصال COM 1C 8.3 - 1C 8.3 آیا امکان وارد کردن دیباگر در اتصال وجود دارد؟
میخواستم از اعضای انجمن بپرسم که آیا هنگام اتصال از طریق یک اتصال COM با استفاده از پردازش از یک پایگاه داده در پلتفرم 8.3.6 (BP 3.0) به ماژول اتصال خارجی یک پایگاه داده خودنویس (همچنین در حال اجرا) میتوان اشکال زدایی کرد. روی پلت فرم 8.3.6) و صادرات از آن را رویه هایی با استفاده از پردازش فراخوانی کنید؟ پایگاه داده ها در حال حاضر مبتنی بر فایل هستند و بر روی یک رایانه شخصی قرار دارند، اما نسخه سرور برنامه ریزی شده است. تا این زمان، من از ساختارهای زیر برای انتقال کد دلخواه برای اجرا از طریق اتصال COM و همچنین برای ثبت خطاها استفاده می کردم. در اینجا قطعاتی از رویه ها در پایگاه داده خودنوشته در ماژول اتصال خارجی آمده است:
تابع ExecuteIn (CodeExecute، پارامتر کمکی = "") صادرات
بازرسی امنیتی()؛ // محافظت در برابر تلاش برای اجرای کد مخرب هنگام اتصال خارجی از طرف یک کاربر دیگرپاسخ = "0" //اگر نیازی به بازگرداندن چیزی نباشد، اگر هیچ خطایی در کد وجود نداشته باشد  // فقط اوکی برمی گرداند  //زیرا کد ارسال شده ممکن است حاوی خطا باشد، سپس در تلاشی اجرای آن را بسته بندی می کنیم.سعی کنید اجرا کنید (CodeExecute)؛ // کد را به عنوان یک رشته در رایانه دیگری از طریق یک اتصال COM (ماژول اتصال خارجی پایه Libra) اجرا کنید.استثنا   //اگر خطایی وجود دارد، متن آن را برگردانید Response = ErrorDetailView(ErrorInfo()); پایان تلاش ; بازگشت پاسخ; تابع EndFunction TestConnection(InParameter, OutParameter) ExportSecurityCheck(); // محافظت در برابر تلاش برای اجرای کد مخرب هنگام اتصال خارجی از طرف یک کاربر دیگر. OutParameter = "ارتباط با پایه مقیاس از طریق اتصال COM وجود دارد!"; بازگشت درست ؛ EndFunction
از BP 3.0 قطعه زیر را اجرا می کنم:
تلاش
Com = New COMObject("V83.COMConnector"); Connection = Com.Connect ("File=""C:\1 c\Base_1C\Libra""; Usr=""ComExchange""; Pwd=""1"";"); TellUser("آزمایش انجام شد! اتصال به پایگاه داده مقیاس وجود دارد"); Exception Error = ErrorDetailView(ErrorInfo()); TellUser("هیچگونه اتصال COM به پایه Libra وجود ندارد! جزئیات"+خطا); Com = تعریف نشده ; برگشت ؛ پایان تلاش ; خارج = ""; در = "1"؛ اگر Connection.Communication Test(In, Out) سپس TellUser("تست ارتباط با پیکربندی مقیاس موفقیت آمیز بود! پاسخ: "+Out); در غیر این صورت TellUser("آزمون ارتباط با پیکربندی مقیاس ناموفق بود! پاسخ: "+Out); EndIf
البته میدانم که نمیتوان عملگر Execute(CodeString1C8) را وارد کرد، اما آیا هنگام فراخوانی یک روش ماژول از راه دور چنین امکانی وجود دارد. اتصال خارجیاز پایگاه داده اصلی Connection.TestConnections(In, Out) تا کد آن را در همان جلسه دیباگر در تابع Security Check() رویه فراخوانی خود وارد کنید؟
من قبلاً به اسنادی که در مورد این موضوع پیدا کردم نگاه کردم. من گزینه هایی را برای فعال کردن اشکال زدایی و نقاط شکست در همه جا در هر دو پیکربندی تنظیم کردم. من هر دو پیکربندی را راه اندازی کردم.
آیا حتی در این شرایط امکان اشکال زدایی رویه Security Check() بیشتر در کنار ماژول اتصال خارجی وجود دارد؟
سوال: آدرس IP اشتباه در اتصال COM
پردازشی وجود دارد که اسناد را از طریق V83.ComConnector بین سرورها منتقل می کند. سرور 1 (نسخه 1C 8.2.19.90) همیشه به سرور 2 (نسخه 8.3.8.2033) متصل می شود. خط اتصال حاوی آدرس IP سرور 2 بود و همه چیز به خوبی کار می کرد. در خود سرور 1 نیز پلتفرم نصب شده را روی سرور 2 نسخه 8.3.9.2033 دیدم (اگر این مهم باشد).
مشکل اینجاست که در سرور 2 آدرس IP تغییر کرد، البته پردازش متوقف شد و وقتی یک IP جدید را در خط اتصال وارد کردم، پردازش خطایی ایجاد می کند که شرح آن هنوز IP قدیمی (!) و متن است. تلاش برای برقراری ارتباط ناموفق بود، زیرا پاسخ مورد نیاز از رایانه دیگری در مدت زمان مورد نیاز دریافت نشد، یا ارتباط برقرار کردبه دلیل پاسخ نادرست از رایانه ای که قبلاً متصل است."
آنها همه چیز را ریبوت کردند، کش ها را پاک کردند و غیره، ادمین ها قسم می خورند که همه چیز از طرف آنها خوب است، شما می توانید از طریق RDP از سروری به سرور دیگر وارد شوید و غیره.
چه مشکلی می تواند داشته باشد، چگونه می توانم آن را حل کنم؟ تمام اینترنت را گشتم و چنین موقعیتی را پیدا نکردم!
پاسخ:() 100% مطمئن! روز دومی که سعی کردم، همانطور که نوشتم، با یک دیباگر به آن نگاه کردم، حتی یک پردازش تک سلولی احمقانه برای آزمایش اتصال ایجاد کردم، آن خطا ظاهر می شود و تمام
سوال: اتصال COM به نسخه های مختلف
سلام به همه.
من یک پایگاه داده ala "Consolidation" دارم که داده های مختلف را از پایگاه های داده مختلف جمع آوری می کند و همه چیز را در یک شمع جمع می کند. مشکل اینه که باید از طریق com به این دیتابیس ها وصل بشی ولی ورژن های مختلف هستن و در نهایت با خطای مشابه مواجه میشم
خطای اتصال!(ExternalProcessing.TransferHistory.Form.Form.Form(12)): خطا هنگام فراخوانی روش زمینه (اتصال) : یک استثنا رخ داد (V83.COMConnector. 1): عدم تطابق بین کلاینت و سرور نسخه 1 C:Enterprise Client نسخه ها متفاوت است و سرور (8.3. 8.1964 - 8.3. 6.2332)، برنامه مشتری: اتصال COM
من یک اتصال را راه اندازی کردم، یکی دیگر قطع شد...
من می دانم که به نوعی، از طریق سرویس کامپوننت، می توانید برای هر نسخه "کلاس های (کانکتورها)" خود را ایجاد کنید و سپس یک New COM Object مطابق با نسخه پلتفرم کلاس ایجاد کنید... شاید من اشتباه می کنم.
کمکم کن تا بر این مشکل غلبه کنم...
پاسخ:همین... سوال رو حذف میکنم..
سوال: خطای Com در پردازش پر کردن
سلام.
8.2 خرده فروشی 1.
من به 8.1 متصل می شوم که یک conf معمولی نیست.
من از طریق com به پایگاه داده متصل می شوم و سعی می کنم یک سند ایجاد کنم، اما هنگام فراخوانی "CreateDocument()" یا "GetObject()" خطایی در رویه رخ می دهد. پردازش پر کردن. شکل را ببینید
من همین کار را در خود دیتابیس 8.1 امتحان می کنم اما هیچ خطایی وجود ندارد و همچنین وارد Filling Processing نمی شوم.
اشتباه چه می تواند باشد؟
پاسخ: توربوک، یک ماژول سند نوشته شده کج!
بعد از 5 دقیقه اضافه شد
او را صدا نمی زنند! او در حال تلاش برای جمع آوری است! اما از آنجایی که هنگام اتصال از طریق ComConnector، مشکل Dialog Mode وجود ندارد، ماژول سند قابل کامپایل نیست.
برای چنین مواردی، زمانی که لازم است کار با یک دیالوگ در یک ماژول شی اجرا شود، از دستورالعمل های پیش پردازنده استفاده کنید
این اشتباه شما نیست، بلکه یک خطا در ماژول سند در پایگاه داده ای است که به آن متصل می شوید.
در پایگاه داده، کد روی کلاینت اجرا می شود و حالت گفتگو وجود دارد، بنابراین همه چیز بدون خطا اتفاق می افتد.
از ComConnector، V8.Application برای اتصال استفاده نکنید، سپس چیزهای رابط در دسترس شما خواهد بود
بعد از 5 دقیقه اضافه شد
=======================================================================================================================
از توضیحات اتصال خارجی (SP) آنچه را که باید در مورد ComConnection بخوانید را با خط برجسته برجسته کردم
شرح:
به طور کلی، کار با 1C:Enterprise 8 از طریق یک اتصال خارجی مشابه کار با 1C:Enterprise در حالت Automation سرور است. تفاوت های اصلی به شرح زیر است:
- در مورد سرور اتوماسیون، یک برنامه کامل 1C: Enterprise 8 راه اندازی می شود و در مورد اتصال خارجی، یک سرور COM نسبتاً کوچک در حال پردازش راه اندازی می شود.
- هنگام کار از طریق اتصال خارجی در دسترس نیست عملکرد، به یک روش مرتبط با سازماندهی رابط کاربری 1C: Enterprise 8؛
- هنگام اجرای یک اتصال خارجی، ماژول برنامه مدیریت شده (ماژول برنامه منظم) پیکربندی 1C: Enterprise 8. نقش آن هنگام کار با یک اتصال خارجی توسط ماژول اتصال خارجی انجام می شود.
- راه اندازی سریع تر اتصال، زیرا نیازی به ایجاد فرآیند جداگانه نیست سیستم عامل، و تمام اقدامات در فرآیند فراخوانی انجام می شود.
- دسترسی سریع تر به ویژگی ها و روش های اشیاء 1C: Enterprise، زیرا سازماندهی یک دسترسی نیازی به ارتباطات بین فرآیندی ندارد.
- مصرف کمتر منابع سیستم عامل
- یک مدیر اتصال COM ایجاد می شود که با کمک آن اتصال برقرار می شود.
- یک تماس با روش Connect مدیر اتصال COM برقرار می شود. روش Connect یک اتصال بیرونی را با پایگاه اطلاع رسانی 1C: Enterprise 8;
- از طریق یک اتصال خارجی، دسترسی به روشها، ویژگیها و اشیاء معتبر پایگاه اطلاعاتی که اتصال با آن برقرار میشود، ایجاد میشود.
اتصال بیرونی فراهم می کند دسترسی کاملبه بافت جهانی آن بنابراین، یک اتصال خارجی به عنوان روشهای آن میتواند داشته باشد: ثابتهای سیستم، مقادیر اشیاء مشخصشده در پیکربندی، که دسترسی به آنها با استفاده از مدیران انجام میشود (به عنوان مثال، ثابتها، شمارشها، فهرستها، اسناد، گزارشهای اسناد، گزارشها. ، پردازش، طرح های انواع ویژگی ها، نمودار حساب ها، طرح های نوع محاسبات، ثبت ها) و همچنین متغیرهای اعلام شده در ماژول اتصال خارجی با کلمه کلیدی Export.
دسترسی:
ادغام.
سوال: اتصال COM، طرح نوع مشخصات
وظیفه این است که از طریق یک اتصال COM، یک عنصر جدید را در یک پلن شناخته شده از انواع مشخصه به صورت برنامه نویسی ایجاد کنیم. ارتباط برقرار است، اینجا همه چیز خوب است.
من اینطور می نویسم:
TypeDescriptionTech = New TypeDescription("DirectoryLink. Counterparties"); PurposeProperties = اتصال. طرح های انواع مشخصه ها. مقاصد خواص مقوله های اشیاء. FindByName("دایرکتوری "افراد")؛ NewElement = اتصال. طرح های انواع مشخصه ها. ویژگی های شی CreateItem(); NewElement. نام = PropertyName; NewElement. PropertyAssignment = PropertyAssignment; NewElement. ValueType = DescriptionTypesTech;
خط آخر کار نمی کند. و این قابل درک است، چنین نوعی را برای پایگاه داده ای که 1C در حال اجرا است پیدا می کند، اما من به یک نوع برای پایگاه داده پیوست نیاز دارم. چگونه آن را بدست آوریم؟
در نسخه من، یک عنصر با نوع مقدار "فهرست سفارشی" به سادگی ایجاد می شود. در اصل کار می کند، اما به نوعی زشت است.
Platformform 8.3. اتصال COM یک پیش نیاز است. راه حل های بدون استفاده از آن مورد توجه نیستند.
پاسخ:
رول. ممنون، کار کرد
سوال: اتصال COM. مشکل پارامتر پرس و جو
پاسخ:
سوال: اتصال Com از پایگاه داده فایل به پایگاه داده فایل
پاسخ:
چاپ (Ctrl+P)
یکی از گزینه های تبادل داده بین پایگاه های داده 1C تبادل از طریق اتصال COM است. با استفاده از اتصال COM، می توانید از یک پایگاه داده 1C به پایگاه داده دیگری متصل شوید و داده ها را بخوانید یا بنویسید. این روش را می توان هم در نسخه های سرویس گیرنده-سرور پایگاه های داده و هم در پایگاه های داده فایل استفاده کرد. این مقاله در مورد این نوع اتصالات در پلت فرم 8.3 بحث می کند
اتصال com
شما می توانید دو نوع شی COM برای برنامه 1C ایجاد کنید. این اتصالات ole است V83.Application و اتصالات com V83.COMConnector . در صورت V83.Applicationیک نسخه تقریباً کامل از برنامه 1C راه اندازی شد. در صورت استفاده V83.COMConnectorیک بخش کوچک سرور راه اندازی شد. سرعت عمل در این مورد بالاتر است، اما برخی از عملکردها ممکن است در دسترس نباشند. به طور خاص، کار با فرم ها و ماژول های رایج که خاصیت کار با اتصالات خارجی برای آنها تنظیم نشده است. بیشتر شما باید استفاده کنید V83.COMConnectorو فقط در صورت عدم عملکرد V83.Application. تفاوت در سرعت عملیات می تواند به ویژه در پایگاه های داده با حجم زیاد قابل توجه باشد. برای پلتفرم 8.2 استفاده شده است V82.Application یا V82.COMConnector
یک اتصال OLE ایجاد کنید
اتصال = COMObject جدید ("V83.Application") ;
یک اتصال COM ایجاد کنید
اتصال = COMObject جدید ("V83.COMConnector");
رشته اتصال
//برای گزینه مشتری-سرور
رشته اتصال= "Srvr = ""ServerName" ";Ref = " "BaseName" ;
/گزینه /For file mode:
رشته اتصال= "File = "PathKBase" "؛ Usr = نام کاربری; Pwd = رمز عبور;
تلاش
اتصال = اتصال . اتصال(ConnectionString)؛
استثنا
Message = New MessageToUser;
پیام . متن =
"اتصال به پایگاه داده ناموفق بود" +
DescriptionErrors(); پیام . برای گزارش ();
پایان تلاش ;
قطع ارتباط
اتصال = تعریف نشده
برای شی V83.Applicationلازم است اتصال را قطع کنید، در غیر این صورت یک جلسه ناقص باقی می ماند که سپس باید به صورت دستی حذف شود. در صورت V83.COMConnectorهنگامی که رویه ای که در آن اتصال برقرار شد، اتصال به طور خودکار قطع می شود و یک نکته کوچک دیگر وجود دارد. برای کاربری که تحت آن اتصال برقرار می شود، چک باکس "درخواست تایید هنگام بستن برنامه" باید در تنظیمات آن غیرفعال باشد.
متد NewObject().
برای ایجاد یک شی جدید، می توانید از متد ()NewObject استفاده کنید، به عنوان مثال:
برای V83.COMConnector
RequestCOM = اتصال NewObject( "درخواست ")
;
TableCOM = اتصال NewObject( "جدول ارزش ها")
;
ArrayCOM = اتصال. NewObject ("آرایه") ;
ViewCOM =Connection.NewObject
برای V83.Application
RequestOLE = اتصال NewObject(" درخواست ")
;
TableOLE = اتصال. NewObject("جدول ارزش ها")
;
ArrayOLE = Connection.NewObject("آرایه" ) ؛
ViewCOM =Connection.NewObject("UniqueIdentifier"، StringUID)؛
RequestCOM . متن ="انتخاب کنید
| موقعیت های سازمان ها. کد،
| موقعیت های سازمان ها. نام
|از | فهرست پست های سازمان ها
چگونه به موقعیت های سازمان ها”;
نتیجه = RequestCOM. اجرا کن()؛
نمونه = نتیجه انتخاب کنید () ؛
انتخاب خداحافظ. بعد()چرخه
چرخه پایان ;
همچنین می توانید از مدیران شی پیکربندی استفاده کنید:
DirectoryCOM = اتصال. دایرکتوری ها نام دایرکتوری
DocumentCOM = اتصال مستندات. نام سند؛
RegisterCOM = اتصال. ثبت اطلاعات. RegisterName ;
دریافت و مقایسه شمارش از طریق اتصال COM
برای مقایسه مقادیر عناصر شمارش تعریف شده در پیکربندی، لازم است این عناصر را به یکی از انواع اولیه تبدیل کنید که مقایسه آن آسان است. این گونه ها می توانند از نوع عددی یا رشته ای باشند. شما می توانید مقدار یک عنصر enumeration را به یک نوع عددی تبدیل کنید:
تعداد مورد = Connection.Directories.Directory1.FindByCode(1).Props1;
PossibleValues = Enum Element.Metadata().Enum Values;
EnumerationElementNumber = PossibleValues.Index(PossibleValues.Find(Connection.XMLString(EnumerationElement)));
اگر EnumerationItemNumber = 0 سپس گزارش دهید( "Enumer value1");
ElseIfEnumerationItemNumber = 1 سپسگزارش ("EnumerationValue2");
endIf;
بازیابی یک شی از طریق COM توسط شناسه
از طریق مدیران اشیاء پیکربندی، یک شی com به دست می آوریم، به عنوان مثال:
DocumentCOM = اتصال مستندات. نام سند؛
سپس یک رشته شناسه منحصر به فرد دریافت می کنیم:
StringUID =Connection.string ( DocumentCOM.UniqueIdentifier())
شناسه = U جدید شناسه منحصر به فرد (StringUID);
با linkByIdentifier = اسناد[DocumentName].GetLink(Identifier);
اگر می خواهید یک شی com را با سند بر اساس شناسه پیدا کنید، باید به این صورت بنویسید:
WidCOM = Connection.NewObject("UniqueIdentifier"، StringUID)؛
LinkByIdentifier = Connection.Documents[DocumentName].GetLink(WidCOM);
یکی از راه های انتقال داده از یک پیکربندی 1C به پیکربندی دیگر، اتصال نرم افزاری با استفاده از COM است. بسیاری از شرکت ها از چندین پایگاه داده مختلف استفاده می کنند که بین آنها باید ارتباطات و وابستگی های خاصی وجود داشته باشد. اگر نه تنها انتقال داده ها، بلکه برای انجام پردازش داده های خاص نیز ضروری باشد، اتصال COM مکانیسم بهینه خواهد بود. توانایی تجزیه و تحلیل داده ها از پایگاه داده 1C دیگر برای هر توسعه دهنده ای مفید است.
ما از طریق COM به پایگاه داده 1C متصل می شویم
برای پیاده سازی اتصال COM در 1C، از مکانیزم خاصی به نام COMConnector استفاده می شود. این آبجکت همراه با پلتفرم نصب می شود و برای اتصال پایگاه های اطلاعاتی استفاده می شود. لازم به ذکر است که برای نسخه های 8.2 و 8.3 از اشیاء با نام های مختلف - به ترتیب "V82.COMConnector" و "V83.COMConnector" استفاده می شود.
به یاد داشته باشید که مدت زمان اتصال COM به پایگاه داده هزینه مجوز دارد - با اجرای همزمان چندین اتصال غافل نشوید. این امر به ویژه برای سازمان هایی که مجوزهای محدودی دارند بسیار مهم است. این مشکل را می توان با کمک کارهای معمولی که در صورت عدم اتصال کاربر فعال به پایگاه اطلاعاتی اجرا می شوند، حل کرد.
برای اینکه بتوانید به پایگاه داده دیگری متصل شوید و اطلاعات لازم را درخواست کنید، باید داده های زیر را بدانید:
- نوع آن چیست - فایل یا سرویس گیرنده-سرور.
- در کجا قرار دارد؛
- از چه نام و رمز عبوری می توانید برای ورود استفاده کنید؟
- شما به چه داده هایی علاقه مند هستید؟
از سه نقطه اول، برای پیاده سازی یک اتصال COM، باید یک رشته از پارامترها ایجاد کنید. بسته به نوع امنیت اطلاعات، متفاوت خواهد بود ظاهر. با استفاده از رشته دریافتی، یک اتصال ایجاد می شود که با کمک آن می توانید داده ها را از پایگاه داده دیگری برای تجزیه و تحلیل و پردازش با استفاده از هر روشی جمع آوری کنید.
Connection ParametersFileIB = "File=""Path_to_database""; Usr=""User_name"";Pwd=""Password"""; Connection ParametersClientServerIB = "Srvr=""Server_Name""; Ref=""Database_Name""; Usr=""User_Name""; Pwd=""Password""";عملکرد اتصال ساده است و اگر همه پارامترها به درستی مشخص شده باشند، نباید سؤالی ایجاد کند. برای سرعت بخشیدن به اشکال زدایی و تجزیه و تحلیل خطاهای احتمالیبهتر است اتصال را در ساختار "Try" محصور کنید. تابع مقداری از نوع "COM object" را برمی گرداند که با آن برای به دست آوردن داده های لازم کار خواهید کرد.
&OnServer Function ConnectToBase() exportConnectionIB Parameters = "File=""E:\1c database\ERP""; Usr=""Administrator"";Pwd=""1"""; V83COMCon= COMObject جدید ("V83.COMConnector"); تلاش برای بازگشت V83COMCon.Connect (پارامترهای اتصال IB); گزارش استثنا (ErrorDescription()); بازگشت تعریف نشده؛ EndAttempt; EndFunctionاز طریق یک اتصال COM نه تنها می توانید داده ها را انتخاب کنید، بلکه آنها را به پایگاه داده ای که به آن متصل می شوید نیز اضافه کنید. به یاد داشته باشید که ما می توانیم 4 نوع داده اولیه را از طریق یک شی COM انتقال دهیم. انواع دیگر باید با استفاده از توابع جستجوی داخلی پلت فرم مشخص شوند. لطفاً توجه داشته باشید که توابع پلتفرم جهانی نیز از طریق یک اتصال COM فراخوانی می شوند.
ما داده ها را از پایگاه داده 1C دریافت می کنیم
پس از دریافت شی مورد نظر، باید داده ها را از پایگاه داده دیگری بخوانید. برای انجام این کار، از یک درخواست از طریق اتصال COM در 1C 8.3 با استفاده از مقدار دریافت شده از نوع "COM object" از تابع استفاده می کنیم. مهم است که ابتدا به پایگاه داده متصل شوید و سپس درخواست را اجرا کنید. اجرا از طریق روش NewObject انجام می شود و نوع شی را به صورت رشته ای به عنوان پارامتر - "Request" مشخص می کند.
رویه &روی سرور TestCOMOnServer() اتصال = ConnectToBase(); اگر TypeValue(Connection) Type("Undefined") سپس RequestBPZO = Connection.NewObject("Request"); RequestBPZO.Text = "انتخاب اول 15 | DirectoryUser.Name به عنوان نام |FROM | Directory.users AS DirectoryUser"; Select = RequestBPZO.Execute().select(); در حالی که Selection.next() حلقه گزارش (Selection.Number); چرخه پایان endIf; پایان رویه >به عنوان مثال، برای به دست آوردن اطلاعات در مورد کاربران یک بخش خاص، از طریق پارامترها در درخواست شرط می گذاریم. یک پارامتر از نوع ساده خواهد بود - یک رشته، و تقسیم یک پیوند به عنصر دایرکتوری "ساختار سازمانی" خواهد بود. نتیجه پرس و جو جدولی با فیلدهای فهرست شده از نوع موجود در پایگاه داده ای است که اتصال COM به آن رخ داده است. اگر نیاز به تبدیل آنها به انواع دیگر دارید، از توابع پلت فرم استاندارد استفاده کنید:
- خط ();
- عدد()؛
- تاریخ().
اگر نیاز به انتقال یک آرایه به پایگاه داده برای انتخاب بر اساس چندین پارامتر، به عنوان مثال، بخش ها دارید، از دستور NewObject نیز استفاده می شود. به طور مشابه، میتوانید فهرست یا جدولی از مقادیر را ارسال کنید و آنها را با عناصر پایگاه داده دیگری از طریق یک اتصال پر کنید. همه برای جستجو در دسترس شما هستند روش های موجوداشیاء و مکانیسم های پلت فرم
RequestBPZO = Connection.NewObject.("درخواست"); RequestBPZO.Text = "اولین 15 را انتخاب کنید | DirectoryUser.Name به عنوان نام | FROM | Directory.Users AS DirectoryUser I WHERE | DirectoryUser.Department B (&NecessaryDepartment) | و DirectoryUser.Name مانند ""%""""""""%" "؛ Array of Departments = Connection.NewObject("Array"); Array of Departments.Add(Connection.Directories.Enterprise Structure.Find By Code("00-000023")); Array of Departments.Add(Connection.Directories.Enterprise Structure.Find By Code("00-000038")); Array of Departments.Add(Connection.Directories.Enterprise Structure.Find By Code("00-000046")); درخواست BPZO.SetParameter("Required Department", Array of Departments); RequestBPZO.SetParameter("RequiredName","Ekaterina"); Select = RequestBPZO.Execute().select(); در حالی که Selection.next() حلقه گزارش (Selection.Name); چرخه پایانهنگام انتقال اسناد یا عناصر دایرکتوری، همیشه مسئله کنترل انتقال یک شی خاص مطرح می شود. با کمک اتصالات COM، چنین مشکلاتی را می توان از طریق یک شناسه منحصر به فرد حل کرد. شما باید با استفاده از تابع "GetLink" و با استفاده از شناسه به عنوان رشته، یک شی را در پایگاه داده افزونه با شناسه از امنیت اطلاعات فعلی پیدا کنید. اگر یکی پیدا نشد، می توانید آن را با استفاده از اتصال COM ایجاد کنید.
StrIdent = String(Directories.Users.FindByCode("00-0000313").UniqueIdentifier()); اگر NOT ValueFilled(Connection.Directories.Users.GetLink(Connection.NewObject("UniqueIdentifier", StrIdent))) سپس NewUser = Connection.Directories.Users.CreateItem(); NewUser.Name = Directories.Users.FindByCode("00-0000313").Name; NewUser.Individual = Directories.Users.FindByCode("00-0000313").Individual; NewUser.Write(); endIf;همچنین، یک اتصال COM حق استفاده از رویه ها و عملکردهای ماژول های رایج 1C را با فعال بودن ویژگی "اتصال خارجی" دارد. علاوه بر این شرط، تابع یا رویه فراخوانده شده باید Export باشد و شامل اقدامات تعاملی انجام شده روی سرور نباشد. در غیر این صورت، خطای نامعتبر بودن عملیات را مشاهده خواهید کرد.
ترکیب..؛ VariableFunction = اتصال..; فراخوانی تابع> نام ماژول عمومی> فراخوانی رویه> نام ماژول عمومی>امکانات اتصال خارجی با پایگاه داده دیگر در 1C بسیار گسترده است و می تواند به شما امکان انجام کارهای زیادی را بدهد. مهم است که بتوانیم ابزارها را به درستی ارزیابی کنیم و راه حل بهینه را انتخاب کنیم. در بیشتر موارد، این مهارت تنها با تجربه یا با مطالعه نمونه هایی از کار متخصصان با تجربه ظاهر می شود.
کلمات کلیدی: COM، اتصال، خارجی، OLE، اتوماسیون، اتصال، ComConnector، Srvr
هنگام استفاده از اتصالات COM 1C: Enterprise 8.0 برای دسترسی به داده ها، مزایای زیر در مقایسه با استفاده از سرور اتوماسیون وجود دارد:
- برقراری اتصال سریعتر، زیرا نیازی به ایجاد یک فرآیند سیستم عامل جداگانه نیست و تمام اقدامات در فرآیند فراخوانی انجام می شود.
- دسترسی سریع تر به ویژگی ها و روش های اشیاء 1C: Enterprise، زیرا سازماندهی یک دسترسی نیازی به ارتباطات بین فرآیندی ندارد.
- مصرف کمتر منابع سیستم عامل
به طور کلی، کار با 1C: Enterprise 8.0 از طریق اتصال COM مشابه کار با 1C: Enterprise در حالت اتوماسیون سرور است. تفاوت های اصلی به شرح زیر است:
- در مورد سرور Automation، یک برنامه کامل 1C: Enterprise 8.0 راه اندازی می شود و در مورد اتصال COM، یک سرور COM نسبتاً کوچک در حال پردازش راه اندازی می شود.
- هنگام کار از طریق اتصال COM، عملکرد به یک روش مرتبط با سازماندهی رابط کاربری 1C: Enterprise 8.0 در دسترس نیست.
- هنگام اجرای یک اتصال COM، ماژول برنامه پیکربندی 1C:Enterprise 8.0 استفاده نمی شود. نقش آن هنگام کار با اتصال COM توسط ماژول اتصال خارجی انجام می شود.
1.1 رویه ایجاد یک اتصال COM
برای سازماندهی دسترسی به داده های 1C: Enterprise 8.0 از طریق اتصال COM، دنباله اقدامات زیر انجام می شود:
- یک شی COM با شناسه V8.COMConnector ایجاد می شود که با کمک آن اتصال برقرار می شود.
- متد Connect شیء V8.COMConnector قبلا ایجاد شده فراخوانی می شود. روش Connect پیوندی را به یک شی اتصال COM با پایگاه اطلاعات 1C:Enterprise 8.0 برمی گرداند.
- از طریق شی اتصال COM دریافتی، به روشها، ویژگیها و اشیاء معتبر پایگاه اطلاعاتی که اتصال با آن برقرار میشود، دسترسی پیدا میکند.
مهم!به دلیل عدم وجود رابط کاربری در اتصال COM، نمی توان از همه اشیا، ویژگی ها و روش ها در اتصال COM استفاده کرد.
1C: اشیاء سازمانی قابل دسترسی خارجی از طریق اتصال COM:
- متغیرها و رویه ها/عملکردهای ماژول اتصال خارجی صادر شده است
- متغیرهای صادر شده و رویه ها/توابع ماژول های رایج
- شامل و حذف کل ماژول ها با تنظیم ویژگی های ماژول های رایج
- شامل و حذف قطعات ماژول های رایج با استفاده از یک پیش پردازنده
- زمینه جهانی 1C: Enterprise 8.0، به استثنای اشیایی که به طور محکم به برنامه مشتری مرتبط هستند (TextDocument، TabularDocument، ...)
1.2 ماژول اتصال خارجی
همانطور که قبلاً ذکر شد، مسئولیت های ماژول برنامه هنگام کار از طریق اتصال COM توسط ماژول اتصال خارجی انجام می شود. این ماژول ممکن است دارای رویه های کنترل کننده رویداد When SystemStarts() و WhenSystemCompletes() باشد که به ترتیب می تواند شامل اقدامات انجام شده پس از مقداردهی اولیه و خاتمه اتصال باشد.
رویه ها، توابع و متغیرهای سراسری تعریف شده در یک ماژول پیوستن خارجی با کلمه کلیدی Export، مانند ماژول برنامه، بخشی از زمینه جهانی می شوند.
1.3 ماژول های رایج
ویژگی های "Client"، "Server" و "External Connection" برای ماژول های رایج معرفی شده اند. آنها برای تعیین استفاده از ماژول ها در نسخه سرویس گیرنده - سرور و در حالت اتصال COM در پیکربندی در نظر گرفته شده اند.
1.4 شیء "V8.COMConnector"
تنها کار حل شده توسط شیء V8.COMConnector COM ایجاد یک اتصال COM با پایگاه اطلاعاتی 1C:Enterprise 8.0 است. تعداد نامحدودی از اتصالات را می توان با استفاده از یک نمونه از شی V8.COMConnector ایجاد کرد. شی V8.COMConnector دارای یک روش اتصال واحد است که برای ایجاد یک اتصال COM با پایگاه اطلاعاتی 1C:Enterprise 8.0 طراحی شده است.
<СтрокаСоединенияИБ>
خط اتصال با سیستم امنیت اطلاعات زنجیره ای از قطعات به شکل Parameter=Value است. قطعات با ";" از یکدیگر جدا می شوند. اگر مقدار حاوی فضای خالی باشد، باید در آن محصور شود نقل قول های دوگانه (").
پارامترهای رایج:
Usr - نام کاربری؛
Pwd - رمز عبور.
پارامتر زیر برای نسخه فایل تعریف شده است:
فایل - دایرکتوری پایگاه اطلاعاتی.
پارامترهای زیر برای گزینه مشتری-سرور تعریف شده است:
Srvr - 1C: نام سرور سازمانی؛
Ref - نام پایگاه اطلاعاتی روی سرور.
روش Connect یک اتصال COM به پایگاه اطلاعات 1C:Enterprise 8.0 برقرار می کند و پیوندی را به شی اتصال COM برمی گرداند.
// یک شی کانکتور ایجاد می شود
V8 = COMObject جدید ("V8.COMConnector");
// یک شی اتصال COM ایجاد می شود
اتصال = V8.Connect("File=""c:\InfoBases\Trade""; Usr=""Director"";")
1.5 شی اتصال COM
یک اتصال COM به پایگاه اطلاعاتی 1C: Enterprise دسترسی کامل به زمینه جهانی آن را فراهم می کند (به «زمینه اجرای ماژول برنامه» مراجعه کنید). بنابراین، یک اتصال COM می تواند به عنوان روش های خود باشد: ثابت های سیستم، مقادیر مشخص شده در پیکربندی اشیایی که با استفاده از مدیران به آنها دسترسی پیدا می کنند (به عنوان مثال، ثابت ها، شمارش ها، دایرکتوری ها، اسناد، گزارش های اسناد، گزارش ها، پردازش، طرح هایی برای انواع ویژگی ها، حساب های طرح ها، طرح های انواع محاسبات، رجیسترها) و همچنین متغیرهای اعلام شده در ماژول اتصال خارجی با کلمه کلیدی Export.
علاوه بر این، اتصال COM دارای یک روش NewObject اضافی است که می تواند برای ایجاد مقادیر از انواع خاصی استفاده شود.
tk = اتصال. NewObject ("ValueTable");
روش رشته به شما امکان می دهد نمایش رشته ای از مقادیر 1C: Enterprise را بدست آورید.
View = Connection.String(Data.UniqueIdentifier());
1.6. ویژگی های کار با اتصال COM
در Automation و در یک اتصال COM، TRUE و FALSE مقادیر زیر را دارند: -1 (منهای یک) و 0.
امکان سازماندهی مجموعه ای از اتصالات COM وجود دارد. در همان زمان، چندین شیء اتصال COM در سرور دریافت کننده 1C: Enterprise ایجاد می شود و زمان کمتری برای برقراری اتصال می گیرد، زیرا نیازی به ایجاد یک شی جدید نیست.
یک شی جدید Query Builder پیاده سازی شده است که برای تولید متون پرس و جو بر اساس تنظیمات مشخص شده طراحی شده است. این شیاز عملکرد سازنده گزارش پشتیبانی می کند که به خروجی گزارش به سند صفحه گسترده و سایر وظایف مربوط به رابط کاربری. این شی را می توان در سرور 1C: Enterprise و در یک اتصال COM استفاده کرد.
هنگام اجرای زبان داخلی در سرور 1C: Enterprise می توانید از اشیاء COM استفاده کنید.
خطاهای COM به استثناهای زبان جاسازی شده تبدیل می شوند.
اگر پیکربندی سعی کند یک شی نامعتبر ایجاد کند، به عنوان مثال. سند صفحه گسترده، در یک ماژول اتصال خارجی، در یک ماژول مشترک، یا در یک ماژول شی، ممکن است اتصال COM برقرار نشود یا به عنوان یک استثنا قطع شود.
یکی از گزینه های تبادل داده بین پایگاه های داده 1C تبادل از طریق اتصال COM است.
با استفاده از اتصال COM، می توانید از یک پایگاه داده 1C به پایگاه داده دیگری متصل شوید و داده ها را بخوانید یا بنویسید. این روش را می توان هم در نسخه های سرویس گیرنده-سرور پایگاه های داده و هم در پایگاه های داده فایل استفاده کرد. در این مقاله به نمونه هایی از این نوع اتصال می پردازیم. نمونه ها از پلتفرم 8.2 استفاده می کنند.
شما می توانید دو نوع شی COM برای برنامه 1C ایجاد کنید. این V82.Applicationو V82.COMConnector. در صورت V82.Applicationیک نسخه تقریباً کامل از برنامه 1C راه اندازی شد. در صورت استفاده V82.COMConnectorیک بخش کوچک سرور راه اندازی شد.
سرعت عمل در این مورد بالاتر است، اما برخی از عملکردها ممکن است در دسترس نباشند. به طور خاص، کار با فرم ها و ماژول های رایج که خاصیت کار با اتصالات خارجی برای آنها تنظیم نشده است. بیشتر شما باید استفاده کنید V82.COMConnectorو فقط در صورت عدم عملکرد V82.Application. تفاوت در سرعت عملیات می تواند به ویژه در پایگاه های داده با حجم زیاد قابل توجه باشد.
پس بیایید شروع کنیم
- بیایید یک شی COM ایجاد کنیم
- برای V82.Applicationاتصال = COMObject جدید ("V82.Application") ;
- برای V82.COMConnectorاتصال = COMObject جدید ("V82.COMConnector");
- بیایید یک رشته اتصال ایجاد کنیم
- برای نسخه سرور پایگاه داده ConnectionString = "Srvr = " "ServerName" ";Ref = " "BaseName" ;
- برای نسخه فایل پایگاه داده ConnectionString = "File = " "PathKBase" "؛ Usr = نام کاربری؛ Pwd = رمز عبور";
- اتصال به پایگاه دادهتلاش اتصال = اتصال. اتصال (ConnectionString)؛ Exception Message = New MessageToUser; پیام. متن = + ErrorDescription() ; پیام. برای گزارش () ; پایان تلاش ;
- قطع ارتباط از پایگاه دادهاتصال = تعریف نشده
برای شی V82.Applicationلازم است اتصال را قطع کنید، در غیر این صورت یک جلسه ناقص باقی می ماند که سپس باید به صورت دستی حذف شود. در صورت V82.COMConnectorهنگامی که رویه ای که در آن اتصال برقرار شد، اتصال به طور خودکار قطع می شود و یک نکته کوچک دیگر وجود دارد.
برای کاربری که تحت آن اتصال برقرار می شود، چک باکس "درخواست تایید هنگام بستن برنامه" باید در تنظیمات آن غیرفعال باشد.
حالا بیایید همه کدها را کنار هم بگذاریم
اتصال = COMObject جدید ("V82.Application") ; //Connection = New COMObject("V82.COMConnector"); ConnectionString = "Srvr = " "Server1C" ";Ref = " "MyBase" "; Usr = Petya; Pwd = 123" ; //ConnectionString = "File = ""С:\MyBase""؛ Usr = Petya؛ Pwd = 123";تلاش اتصال = اتصال. اتصال (ConnectionString)؛ Exception Message = New MessageToUser; پیام. متن = "نمی توان به پایگاه داده متصل شد"+ DescriptionError() ; پیام. برای گزارش () ; پایان تلاش ; اتصال = تعریف نشده
برای نوع اتصال V82.Applicationاین روش برای شی COM که در ابتدا ایجاد شده بود و برای استفاده می شود V82.COMConnectorروش برای اتصال اعمال می شود. کار بیشتر با درخواست ادامه می یابد به معنی استاندارد 1C. در کد به شکل زیر است:
درخواست = اتصال. NewObject("درخواست") ; // برای V82.COMConnector درخواست = اتصال. NewObject("درخواست") ; // برای V82.Application درخواست. متن = "انتخاب کنید | موقعیت های سازمان ها. کد، | موقعیت های سازمان ها. نام|از | فهرست پست های سازمان ها به عنوان موقعیت های سازمان ها"; نتیجه = درخواست اجرا کن()؛ نمونه = نتیجه انتخاب کنید() ؛ انتخاب خداحافظ. Next() Loop EndLoop ;
برای نسخه 1C: Enterprise 8.3 همه چیز بدون تغییر باقی می ماند به جز اینکه هنگام ایجاد اشیاء COM باید از آن استفاده کنید "V83.COMConnector"یا "V83.Application".
تجزیه سایت چیست؟.