Thanks
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
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:
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.
Huh. Never noticed that. Wouldn't have used it if I had.
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:
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:
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.
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 . 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')
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.