Automation Professionals' Blob Server Module

Thanks :laughing:

how i can get your module?

@Francisco_Ochoa scroll up a few comments and you'll see the download link

where is the link> i didnt see it , if you can help me i will be very thankfully

It's literally 6 comments up from your post

Automation Professionals' Blob Server Module - 3rd Party Modules - Inductive Automation Forum

1 Like

how its work? how can i install it?

Have you read this entire topic? And the documentation linked in the first comment? Do that first.

Quick link to comment #1:

1 Like


i dont have idea what more i need to do , i never used Named Queries

I don't recognize that screenshot. (SSMS?)

Don't use SSMS for this.

Do you have blobs loaded into your database yet? If not, do that first.

Meanwhile, review all of the NQ videos in the university:

That's the "query builder" that's included in the Designer, which attempts to provide a graphical builder for SQL queries.

@Francisco_Ochoa drop out of that. It's worse than a crutch - it's a "mobility aid" that will actively cause you harm. The SQL involved to use Phil's module here is not complicated, and you'll be better off learning it properly.

2 Likes

Huh. Never noticed that. Wouldn't have used it if I had. :man_shrugging:

1 Like

This will be a great tool if I can get it working, thanks for your contribution!

I'm hoping for some pointers. All I am able to get when testing the url in chrome is a broken image icon:
result


When I check the gateway logs (assuming I'm looking in the correct place, I'm still learning), I'm not seeing any info RE blob server except when I start/restart the module. There were also no messages in console of chrome. I feel I'm missing something simple...I've tried several different variations to column type, the INSERT statement, etc., to no avail.


Table T-SQL:

CREATE TABLE [dbo].[parts](
	[PartNumber] [varchar](20) NOT NULL,
	[image] [varbinary](max) NULL,
 CONSTRAINT [PK_parts] PRIMARY KEY CLUSTERED 
(
	[PartNumber] ASC
)WITH (PAD_INDEX = OFF, STATISTICS_NORECOMPUTE = OFF, IGNORE_DUP_KEY = OFF, ALLOW_ROW_LOCKS = ON, ALLOW_PAGE_LOCKS = ON, OPTIMIZE_FOR_SEQUENTIAL_KEY = OFF) ON [PRIMARY]
) ON [PRIMARY] TEXTIMAGE_ON [PRIMARY]
GO


Test record INSERT T-SQL:
I don't currently have access to perform BULK operations, so I encoded a test image to base64 using Python and performed my insert like this (simple smiley image)

INSERT INTO [parts] (PartNumber,image) VALUES ('smile',CONVERT(varbinary(max),''))


My NQ:
NQ Authoring

NQ Testing
edit: I just noticed every run in testing produces random "Content" value

You should not be using CONVERT when inserting images to the DB. Use a "prep" insert or named query where the image file bytes are passed in true binary format into the table. The SQL would look like:

INSERT INTO parts (PartNumber, image) VALUES (?, ?)

with the name and bytes supplied as parameters.

1 Like

I was using an old Python script to encode images to base64, so when I attempted to INSERT, SSMS suggested CONVERT to turn that long piece of encoded text into a varbinary(max). I threw CONVERT in there which satisfied the query, but was not the correct way to handle it as you pointed out. I had a feeling the INSERT wasn't right but couldn't figure out why, makes sense now :man_facepalming:. Your "prep" comment confused me at first as I was only using SSMS for the INSERT, but I got it now so thank you!


FYI, what I used to INSERT image to table:

query = 'INSERT INTO parts (PartNumber,image) VALUES (?,?)'
partnum = 'smile'
picfile = system.file.readFileAsBytes('C:/temp/smile.png')
system.db.runPrepUpdate(query, [partnum,picfile], 'IGN_DB')
3 Likes

Iā€™m trying to use the Blob Server Module ver 1.1.0 (b231421939) to retrieve a PDF from a Sql Server table and display it using a perspective link component. The Named query testing tool has no problem retrieving the PDF, but I cannot get any browser to retrieve the document.

Using numerous variants of this url only generates a 404 errorā€¦

<correct gw designation here>/system/blob/HelpPdfTest-T67/HelpPdfTest_2?file_id="Check Scale.pdf"

<correct gw designation here>/system/blob/HelpPdfTest-T67/HelpPdfTest_2?file_id=Check#20Scale.pdf

<correct gw designation here>/system/blob/HelpPdfTest-T67/HelpPdfTest_2?file_id=Check Scale.pdf

HTTP ERROR 404 Not Found

URI: /system/blob/HelpPdfTest-T67/HelpPdfTest_2
STATUS: 404
MESSAGE: Not Found

There are no seemingly relevant messages in the gateway log.

Tried numerous things including ā€¦

  • Different gateways
  • Different Browsers
  • Different PDFs
  • Different file ids (with and without spaces etc.)
  • And just in caseā€¦
    • Using Integer ID
    • Renaming each individual object one at a time
  • etcā€¦

Any ideas?

Encode spaces with %20, not #20. Might need to encode the hyphen in your project name. Do not include quotes around your string parameters.

(Use java.net.URLEncoder on each string parameter to ensure it is done correctly.)

Also, do you have permissions on the NQ?

Also, is the project a leaf project? And enabled?

Are you sure your DB is returning a BLOB column (you should not see string content when testing) ?

Thanks for the quick reply.
Yep. #20 was a brain fart. %20 does same. It doesn't seem to care about the space.
Nope. No permissions on the NQ (zone and role are "Any").
I'll check out URLEncoder shortly.

Test project is tiny, stand-alone, and enabled.
Not sure about blob. We tried both varchar(MAX) and varbinary(MAX) as column type. Maybe I need a bit of education here.

varchar is definitely wrong. varbinary should work. Don't cast it.

(Show your SQL)

CREATE TABLE [dbo].[FILLER_HELP_FILES_TEST](
	[rec_id] [int] IDENTITY(1,1) NOT NULL,
	[file_id] [varchar](50) NOT NULL,
	[file_blob] [varchar](max) NOT NULL,
	[id] [int] NOT NULL
) ON [PRIMARY] TEXTIMAGE_ON [PRIMARY]

I'll switch back to varbinary in a little while.